web前端基础知识汇总有哪些?

qilundianshangcn qilundianshangcn     2022-12-10     204

关键词:

javascript: JavaScript中如何检测一个变量是一个String类型?请写出函数实现 typeof(obj) === "string" typeof obj === "string" obj.constructor === String 请用js去除字符串空格? 方法一:使用replace正则匹配的方法 去除所有空格: str = str.replace(/s*/g,""); 去除两头空格: str = str.replace(/^s*|s*$/g,""); 去除左空格: str = str.replace( /^s*/, “”); 去除右空格: str = str.replace(/(s*$)/g, ""); str为要去除空格的字符串,实例如下: var str = " 23 23 "; var str2 = str.replace(/s*/g,""); console.log(str2); // 2323 方法二:使用str.trim()方法 str.trim()局限性:无法去除中间的空格,实例如下: var str = " xiao ming "; var str2 = str.trim(); console.log(str2); //xiao ming 同理,str.trimLeft(),str.trimRight()分别用于去除字符串左右空格。 方法三:使用jquery,$.trim(str)方法 $.trim(str)局限性:无法去除中间的空格,实例如下: var str = " xiao ming "; var str2 = $.trim(str) console.log(str2); // xiao ming 你如何获取浏览器URL中查询字符串中的参数? 测试地址为:http://www.runoob.com/jquery/misc-trim.html?channelid=12333&name=xiaoming&age=23 实例如下: function showWindowHref() var sHref = window.location.href; var args = sHref.split(‘?‘); if(args[0] == sHref) return ""; var arr = args[1].split(‘&‘); var obj = ; for(var i = 0;i< arr.length;i++) var arg = arr[i].split(‘=‘); obj[arg[0]] = arg[1]; return obj; var href = showWindowHref(); // obj console.log(href[‘name‘]); // xiaoming js 字符串操作函数 我这里只是列举了常用的字符串函数,具体使用方法,请参考网址。 concat() – 将两个或多个字符的文本组合起来,返回一个新的字符串。 indexOf() – 返回字符串中一个子串第一处出现的索引。如果没有匹配项,返回 -1 。 charAt() – 返回指定位置的字符。 lastIndexOf() – 返回字符串中一个子串最后一处出现的索引,如果没有匹配项,返回 -1 。 match() – 检查一个字符串是否匹配一个正则表达式。 substr() 函数 -- 返回从string的startPos位置,长度为length的字符串 substring() – 返回字符串的一个子串。传入参数是起始位置和结束位置。 slice() – 提取字符串的一部分,并返回一个新字符串。 replace() – 用来查找匹配一个正则表达式的字符串,然后使用新字符串代替匹配的字符串。 search() – 执行一个正则表达式匹配查找。如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。 split() – 通过将字符串划分成子串,将一个字符串做成一个字符串数组。 length – 返回字符串的长度,所谓字符串的长度是指其包含的字符的个数。 toLowerCase() – 将整个字符串转成小写字母。 toUpperCase() – 将整个字符串转成大写字母。 怎样添加、移除、移动、复制、创建和查找节点? 1)创建新节点 createDocumentFragment() //创建一个DOM片段 createElement() //创建一个具体的元素 createTextNode() //创建一个文本节点 2)添加、移除、替换、插入 appendChild() //添加 removeChild() //移除 replaceChild() //替换 insertBefore() //插入 3)查找 getElementsByTagName() //通过标签名称 getElementsByName() //通过元素的Name属性的值 getElementById() //通过元素Id,唯一性 写出3个使用this的典型应用 (1)、在html元素事件属性中使用,如: <input type=”button” onclick=”showInfo(this);” value=”点击一下”/> (2)、构造函数 function Animal(name, color)   this.name = name;   this.color = color; (3)、input点击,获取值 <input type="button" id="text" value="点击一下" /> <script type="text/javascript"> var btn = document.getElementById("text"); btn.onclick = function() alert(this.value); //此处的this是按钮元素 </script> (4)、apply()/call()求数组最值 var numbers = [5, 458 , 120 , -215 ]; var maxInNumbers = Math.max.apply(this, numbers); console.log(maxInNumbers); // 458 var maxInNumbers = Math.max.call(this,5, 458 , 120 , -215); console.log(maxInNumbers); // 458 比较typeof与instanceof? 相同点:JavaScript 中 typeof 和 instanceof 常用来判断一个变量是否为空,或者是什么类型的。 typeof的定义和用法:返回值是一个字符串,用来说明变量的数据类型。 细节: (1)、typeof 一般只能返回如下几个结果:number,boolean,string,function,object,undefined。 (2)、typeof 来获取一个变量是否存在,如 if(typeof a!="undefined")alert("ok"),而不要去使用 if(a) 因为如果 a 不存在(未声明)则会出错。 (3)、对于 Array,Null 等特殊对象使用 typeof 一律返回 object,这正是 typeof 的局限性。 Instanceof定义和用法:instanceof 用于判断一个变量是否属于某个对象的实例。 实例演示: a instanceof b?alert("true"):alert("false"); //a是b的实例?真:假 var a = new Array(); alert(a instanceof Array); // true alert(a instanceof Object) // true 如上,会返回 true,同时 alert(a instanceof Object) 也会返回 true;这是因为 Array 是 object 的子类。 function test(); var a = new test(); alert(a instanceof test) // true 细节: (1)、如下,得到的结果为‘N’,这里的 instanceof 测试的 object 是指 js 语法中的 object,不是指 dom 模型对象。 if (window instanceof Object) alert(‘Y‘) else alert(‘N‘); // ‘N‘ 如何理解闭包? 1、定义和用法:当一个函数的返回值是另外一个函数,而返回的那个函数如果调用了其父函数内部的其它变量,如果返回的这个函数在外部被执行,就产生了闭包。 2、表现形式:使函数外部能够调用函数内部定义的变量。 3、实例如下: (1)、根据作用域链的规则,底层作用域没有声明的变量,会向上一级找,找到就返回,没找到就一直找,直到window的变量,没有就返回undefined。这里明显count 是函数内部的flag2 的那个count 。 var count=10; //全局作用域 标记为flag1 function add() var count=0; //函数全局作用域 标记为flag2 return function() count+=1; //函数的内部作用域 alert(count); var s = add() s();//输出1 s();//输出2 4、变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域。 变量的作用域分类:全局变量和局部变量。 特点: 1、函数内部可以读取函数外部的全局变量;在函数外部无法读取函数内的局部变量。 2、函数内部声明变量的时候,一定要使用var命令。如果不用的话,你实际上声明了一个全局变量! 5、使用闭包的注意点 1)滥用闭包,会造成内存泄漏:由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。 2)会改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。 什么是跨域?跨域请求资源的方法有哪些? 1、什么是跨域? 由于浏览器同源策略,凡是发送请求url的协议、域名、端口三者之间任意一与当前页面地址不同即为跨域。存在跨域的情况: 网络协议不同,如http协议访问https协议。 端口不同,如80端口访问8080端口。 域名不同,如qianduanblog.com访问baidu.com。 子域名不同,如abc.qianduanblog.com访问def.qianduanblog.com。 域名和域名对应ip,如www.a.com访问20.205.28.90. 2、跨域请求资源的方法: (1)、porxy代理 定义和用法:proxy代理用于将请求发送给后台服务器,通过服务器来发送请求,然后将请求的结果传递给前端。 实现方法:通过nginx代理; 注意点:1、如果你代理的是https协议的请求,那么你的proxy首先需要信任该证书(尤其是自定义证书)或者忽略证书检查,否则你的请求无法成功。 (2)、CORS 【Cross-Origin Resource Sharing】 定义和用法:是现代浏览器支持跨域资源请求的一种最常用的方式。 使用方法:一般需要后端人员在处理请求数据的时候,添加允许跨域的相关操作。如下: res.writeHead(200, "Content-Type": "text/html; charset=UTF-8", "Access-Control-Allow-Origin":‘http://localhost‘, ‘Access-Control-Allow-Methods‘: ‘GET, POST, OPTIONS‘, ‘Access-Control-Allow-Headers‘: ‘X-Requested-With, Content-Type‘ ); (3)、jsonp 定义和用法:通过动态插入一个script标签。浏览器对script的资源引用没有同源限制,同时资源加载到页面后会立即执行(没有阻塞的情况下)。 特点:通过情况下,通过动态创建script来读取他域的动态资源,获取的数据一般为json格式。 实例如下: <script> function testjsonp(data) console.log(data.name); // 获取返回的结果 </script> <script> var _script = document.createElement(‘script‘); _script.type = "text/javascript"; _script.src = "http://localhost:8888/jsonp?callback=testjsonp"; document.head.appendChild(_script); </script> 缺点: 1、这种方式无法发送post请求(这里) 2、另外要确定jsonp的请求是否失败并不容易,大多数框架的实现都是结合超时时间来判定。 谈谈垃圾回收机制方式及内存管理 回收机制方式 1、定义和用法:垃圾回收机制(GC:Garbage Collection),执行环境负责管理代码执行过程中使用的内存。 2、原理:垃圾收集器会定期(周期性)找出那些不在继续使用的变量,然后释放其内存。但是这个过程不是实时的,因为其开销比较大,所以垃圾回收器会按照固定的时间间隔周期性的执行。 3、实例如下: function fn1() var obj = name: ‘hanzichi‘, age: 10; function fn2() var obj = name:‘hanzichi‘, age: 10; return obj; var a = fn1(); var b = fn2(); fn1中定义的obj为局部变量,而当调用结束后,出了fn1的环境,那么该块内存会被js引擎中的垃圾回收器自动释放;在fn2被调用的过程中,返回的对象被全局变量b所指向,所以该块内存并不会被释放。 4、垃圾回收策略:标记清除(较为常用)和引用计数。 标记清除: 定义和用法:当变量进入环境时,将变量标记"进入环境",当变量离开环境时,标记为:"离开环境"。某一个时刻,垃圾回收器会过滤掉环境中的变量,以及被环境变量引用的变量,剩下的就是被视为准备回收的变量。 到目前为止,IE、Firefox、Opera、Chrome、Safari的js实现使用的都是标记清除的垃圾回收策略或类似的策略,只不过垃圾收集的时间间隔互不相同。 引用计数: 定义和用法:引用计数是跟踪记录每个值被引用的次数。 基本原理:就是变量的引用次数,被引用一次则加1,当这个引用计数为0时,被视为准备回收的对象。梁婖婷英文名

一个合格的web前端工程师要掌握的知识点汇总

Web前端开发人员使用的技术CSS和HTML、JavaScript,根据设计师设计的雏形来编写代码。布局,框架,浏览器涉及到不同的领域知识广度,把网站界面更好地呈现给用户。那么问题来了,初学Web前端需要掌握哪些知... 查看详情

web前端技巧-es6新特性与重点知识汇总

前端开发使用ES6框架已经不是什么新鲜的事情了,现如今也有越来越多的同学选择使用它,但随着ES6的更新迭代,一些新的特性很多同学并不了解,今天小千就来给大家介绍一下,记得收藏一下啦。一、ES6变... 查看详情

web前端工程师需要掌握的技能有哪些?

Web前端工程师需要掌握的技能有哪些?Web前端开发技术包括HTML、CSS、Js,随着时代的发展前端开发技术逐渐演变成html5,css3,JQuery。Web前端开发工程师要与交互设计师、视觉设计师以及产品经理沟通,同时还... 查看详情

web前端培训课程内容都有哪些?

web前端培训课程内容包括三个部分:基础部分、设计部分和代码部分。web前端培训推荐粤嵌IT培训,该机构师资力量强大,口碑极佳。web前端培训课程内容具体如下:1、基础部分,包含美术基础和PS、AI的使用。PS需要学习常用工... 查看详情

web前端培训都有哪些课程

...技术-网站前后端交互、jQuery交互效果开发第三阶段NodeJS前端架构及后台开发:版本控制工具、NodeJS核心技术第四阶段前端框架:Vuejs全家桶-Vue、React框架-React、微信小程序、Flutter第五阶段小程序开发:能够独立开发小程序,提... 查看详情

学完web前端后发展方向有哪些呢?

作为初级前端工程师要熟练掌握html,h5,jquery,css或css3,bootstrap,且能够快速的实现效果图布局和排版做一些前端交互。中高级前端应该了解和使用一个或多个css框架和js框架做交互数据处理。那么,掌握... 查看详情

web前端需要哪些技术

我打算学web前端开发,除了ps外,我会html、css、js、jquery、ajax等,请问如果从事这些技术的工作,算是web前端开发吗?另外,我用这些技术去就业,会是哪些方面或者哪些职位呢,北京的工资大概多少?还能往哪个方向发展??... 查看详情

零基础转行学web前端,需要掌握哪些技术?

前端工程师,也叫Web前端开发工程师。他是随着Web发展,细分出来的行业。尤其是现在互联网时代,Web技术应用更加广泛。网站、手机app、营销H5等等都离不开Web技术。Web前端人才的需求量也是与日俱增,很多人... 查看详情

必备的web前端技术有哪些?

...得更远。你需要打好HTML、CSS、和JavaScript前端开发的三大基础知识,熟练掌握主流的前端框架有Vue、React和Angular,了解服务端开发,掌握前端工程化。1、基础技术前端三大基础HTML、CSS和JSHTML,翻译过来就是超文本标记... 查看详情

web前端培训:常用的web前端开发框架有哪些?

学习web前端技术的时候,我们会学到开发框架这一课,web前端的开发框架是有很多的,有一些是常用的,那么常用的Web前端开发框架有哪些呢?来看看下面的详细介绍。常用的Web前端开发框架有哪些?程序员常... 查看详情

前端技术栈都有哪些

...画特效学习HTML+CSS搭建网页、CSS动画特效、PhotoShop切图等基础知识,获得初级Web前端工程师技能,主要进行PC端网页制作与样式设计实现,能够配合UI设计师进行项目开发。2、移动端页面制作与响应式实现讲解移动端布局与设备... 查看详情

web前端必备-nginx知识汇总(代码片段)

一、Nginx简介Nginx是一个高性能、轻量级的Web和反向代理服务器,其特点是占有内存及资源少、抗并发能力强。Nginx安装简单、配置简洁、启动快速便捷、支持热部署、支持SSL、拥有高度模块化的设计。Nginx的主要功能有:Web服务器... 查看详情

web前端开发应该具备哪些知识

1.HTML5+CSS32.JavaScript3.JavaWeb4.前端框架开发boostrap.js、node.js、Angular.js、react.js、jQuery.js、vue.js5.小程序开发6.可视化大数据Echart.js7.webpack8.ES6语法9.TypeScript10.gulp工具11.stylus/less/Sass12.git和svn工具13.gith 查看详情

web前端技巧-es6新特性与重点知识汇总

ES6框架的新特性我们今天再来介绍其他的一些,还是带好写本本做好笔记,我们马上开始。七、扩展运算符扩展运算符(spread)是三个点(…)。它好比rest参数的逆运算,将一个数组转为用逗号分隔的... 查看详情

web前端技巧-es6新特性与重点知识汇总

ES6的新特性到这里就是第三期了也是最后一期,今天我们将把剩余的几个ES6特性介绍完毕,希望能够给同学带来帮助,还是带好小本本我们开始了。十三、PromisePromise是异步编程的一种解决方案,比传统的解决方... 查看详情

前端开发必学的技术都有哪些?

...移动端,整理网页开发技巧。3、预编译css技术:less、sass基础知识、以及插件的运用、BootStrap源码分析。能够熟练使用less、sass完成项目开发,深入了解BootStrap。4、使用HTML、CSS、LESS、SASS等技术完成网页项目实战。通过项目掌握... 查看详情

web前端学习技巧有哪些?本文给你答案

随着互联网的快速发展,web前端技术在不断的更新,有着美好前景的web前端岗位引起了很多人的关注,很多人都开始报班学习web前端技术.那么web前端学习技巧有哪些?来看看下面的详细介绍。web前端学习技巧有哪... 查看详情

想从事web前端开发工作,需要掌握哪些知识?

跟我一起对标各个厂的前端任职要求吧。网易掌握HTML、CSS、Js,了解http协议以及相关开发调式工具掌握一定的前端框架(React、Vue、Angular、jQuery等)掌握基础数据结构的原理和应用百度精通JavaScript,包括基本的... 查看详情