ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
[TOC] ## 1.substr和substring的区别 ~~~ var str = "hello world" //获取局部 console.log(str.slice(0)); //hello world //起始下标,终止下标 console.log(str.substr(0,3)) //hel //起始下标,终止下标 console.log(str.substring(0,4)) //hell //起始下标,截取长度 ~~~ ## AJAX的工作原理: ``` (1) 创建Ajax异步调用对象 (2) 创建一个新的HTTP请求,并指定该HTTP请求的方法、URL及验证信息 与服务器建立 (3) 发送HTTP请求 (4) 接受服务器的返回数据 ``` ## 使用正则表达式验证邮箱格式 ~~~ var reg = /^(\w)+(\.\w+)*@(\w)+((\.\w{2,3}){1,3})$/; var email = "example@qq.com"; console.log(reg.test(email)); // true ~~~ ###22.http 和 https 有何区别?如何灵活使用?   http是HTTP协议运行在TCP之上。所有传输的内容都是明文,客户端和服务器端都无法验证对方的身份。 https是HTTP运行在SSL/TLS之上,SSL/TLS运行在TCP之上。所有传输的内容都经过加密,加密采用对称加密,但对称加密的密钥用服务器方的证书进行了非对称加密。此外客户端可以验证服务器端的身份,如果配置了客户端验证,服务器方也可以验证客户端的身份 ### 26.什么是mvvm mvc是什么区别 原理 一、MVC(Model-View-Controller) MVC是比较直观的架构模式,用户操作->View(负责接收用户的输入操作)->Controller(业务逻辑处理)->Model(数据持久化)->View(将结果反馈给View)。 MVC使用非常广泛,比如JavaEE中的SSH框架   ### 三、MVVM(Model-View-ViewModel) 如果说MVP是对MVC的进一步改进,那么MVVM则是思想的完全变革。它是将“数据模型数据双向绑定”的思想作为核心,因此在View和Model之间没有联系,通过ViewModel进行交互,而且Model和ViewModel之间的交互是双向的,因此视图的数据的变化会同时修改数据源,而数据源数据的变化也会立即反应view。 ! ### 50、浏览器是如何渲染页面的? 渲染的流程如下: ### 52:事件委托   事件委托就是利用的DOM事件的事件捕获阶段。把具体dom上发生的事件,委托给更大范围的dom去处理。好比送信员,如果每次都把信件送给每一户,非常繁琐。但是如果交给一个大范围的管理者,比如小区的传达室,那么事情会变得非常简单。事件委托就类似这种原理,我页面中有很多按钮,如果不使用事件委托,我只能在每个按钮上注册事件。非常麻烦。但如果我把事件注册在一个大范围的div(假设所有的按钮都在这个div中),那么我只要注册一次事件,就可以处理所有按钮(只要按钮包含在上述div中)事件的响应了 --------------------- 作者:胖梅 来源:CSDN 原文:https://blog.csdn.net/xm1037782843/article/details/80708533 版权声明:本文为博主原创文章,转载请附上博文链接! ### 54:从输入url到显示页面,都经历了什么 第一步:客户机提出域名解析请求,并将该请求发送给本地的域名服务器。 第二步:当本地的域名服务器收到请求后,就先查询本地的缓存,如果有该纪录项,则本地的域名服务器就直接把查询的结果返回。 第三步:如果本地的缓存中没有该纪录,则本地域名服务器就直接把请求发给根域名服务器,然后根域名服务器再返回给本地域名服务器一个所查询域(根的子域)的主域名服务器的地址。 第四步:本地服务器再向上一步返回的域名服务器发送请求,然后接受请求的服务器查询自己的缓存,如果没有该纪录,则返回相关的下级的域名服务器的地址。 第五步:重复第四步,直到找到正确的纪录。 --------------------- 作者:胖梅 来源:CSDN 原文:https://blog.csdn.net/xm1037782843/article/details/80708533 版权声明:本文为博主原创文章,转载请附上博文链接! ### 第2种解释: 一般会经历以下几个过程: 1、首先,在浏览器地址栏中输入url 2、浏览器先查看浏览器缓存-系统缓存-路由器缓存,如果缓存中有,会直接在屏幕中显示页面内容。若没有,则跳到第三步操作。 3、在发送http请求前,需要域名解析(DNS解析)(DNS(域名系统,Domain Name System)是互联网的一项核心服务,它作为可以将域名和IP地址相互映射的一个分布式数据库,能够使人更方便的访问互联网,而不用去记住IP地址。),解析获取相应的IP地址。 4、浏览器向服务器发起tcp连接,与浏览器建立tcp三次握手。(TCP即传输控制协议。TCP连接是互联网连接协议集的一种。) 5、握手成功后,浏览器向服务器发送http请求,请求数据包。 6、服务器处理收到的请求,将数据返回至浏览器 7、浏览器收到HTTP响应 8、读取页面内容,浏览器渲染,解析html源码 9、生成Dom树、解析css样式、js交互 10、客户端和服务器交互 11、ajax查询 --------------------- 作者:胖梅 来源:CSDN 原文:https://blog.csdn.net/xm1037782843/article/details/80708533 版权声明:本文为博主原创文章,转载请附上博文链接! ### 写出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 --------------------- 作者:wdlhao 来源:CSDN 原文:https://blog.csdn.net/wdlhao/article/details/79079660 版权声明:本文为博主原创文章,转载请附上博文链接!