| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 面试基础知识 -> 正文阅读 |
|
[JavaScript知识库]面试基础知识 |
vue?? ? 0.vue数组改变但是数据没有同步更新的(vue不能检测以下数组的变动的解决方法) a>利用索引直接设置一个数组项时,如vm.items[indexOfItem] = newValue; ?vm.$set(vm.items, indexOfItem, newValue)或者vm.items.splice(indexOfItem, 1, newValue) b>当你修改数组的长度时,例如:vm.items.length = newLength; vm.items.splice(newLength) 1.为什么不建议用索引index(重绘) a)key的作用主要是为了高效的更新虚拟DOM b)当以index为key值时,如果数组长度发生变化,会导致key的变化,比如删除其中某一项,那么index会相应变化。所以用index作为key和不加index没有什么区别,都不能提升性能。一般用每项数据的唯一值来作为key,就算数组长度变化,也不会影响到这个key 2.如何解决props层级过深的问题 1)使用vuex (2)传递数据,使用以下接收(均不含被props接收的数据) this.$attrs 接收属性($attrs可以接受上级传递过来的属性,上级绑定v-bind=’$attrs’) this.$listeners 接收事件(不含被 .native 修饰符的事件) 3.解决非工程化项目初始化页面闪动问题?闪烁花括号{{}} vue页面在加载的时候闪烁花括号{{}},使用v-cloak,隐藏未编译时候的标签 //css样式 [v-cloak] { ????display: none; } //html代码? <div v-cloak>{{ text }}</div> 4.路由懒加载 a)vue异步组件技术 ==== 异步加载 { path: '/home', name: 'home',?component: resolve =>?require(['@/components/home'],resolve)} b)路由懒加载(使用import) const 组件名=() => import('组件路径'); const Home = () => import('@/components/home') c)webpack提供的require.ensure() 多个路由指定相同的chunkName,会合并打包成一个js文件。 { path: '/home', name: 'home', component: r => require.ensure([], () => r(require('@/components/home')), 'demo') } 5.vue中的代理proxy jsonp、cors、Node中间件代理(两次跨域)、nginx反向代理 CORS支持所有类型的HTTP请求,是跨域HTTP请求的根本解决方案。 JSONP只支持GET请求,JSONP的优势在于支持老式浏览器,以及可以向不支持CORS的网站请求数据。 不管是Node中间件代理还是nginx反向代理,主要是通过同源策略对服务器不加限制。 日常工作中,用得比较多的跨域方案是cors和nginx反向代理。 6.vuex的核心概念 state => 基本数据 getters => 从基本数据派生的数据 mutations => 修改数据,同步 actions => 修改数据,异步 modules => 模块化Vuex 7.vue如何优化首屏加载速度? (1)按需加载组件,不一次性加载所有组件 (2)减少打包js,如果打包后的js文件过大,会阻塞加载。如下: B、在vue.config.js文件中配置: config.externals({ ??????vue: 'Vue', ?}) 配置两个步骤,不打包vue (3)关闭sourcemap,开启压缩代码 vue.config.js文件中配置:productionSourceMap: false, (4)加个好看的loading效果 8.vue原理 https://blog.csdn.net/weixin_43972437/article/details/1072for1071 js0.遍历对象的方法: for...in? 遍历对象所有可枚举 Object.keys(obj);Object.values(obj;一个表示给定对象的所有可枚举属性的字符串数组。 Object.getOwnPropertyNames(obj),返回一个数组,包含对象自身的所有属性(包含不可枚举属性),如下: Object.getOwnPropertyNames(obj).forEach(function(key){ console.log(key+ '---'+obj[key]) }) ps:for in遍历的是数组的索引(即键名);而for of遍历的是数组元素值,不包括数组的原型属性method和索引name。 1.typeof ,instance of,Object.prototype.toString.call JavaScript 里使用?typeof?来判断数据类型,只能区分基本类型,即 “number”,”string”,”undefined”,”boolean”,”object” 五种,null 和 数组,object,结果都为object。 instanceof不能检测出number、boolean、string、undefined、null、symbol类型, null、undefined没有construstor方法,因此constructor不能判断undefined和null。 Object.prototype.toString.call(var)?能判断具体的类型。
2.普通函数与箭头函数 箭头函数没有constructor,所以不能使用new调用;不能通过bind、call、apply改变this指向。 3.eval()函数 eval() 函数计算 JavaScript 字符串,并把它作为脚本代码来执行。如果参数是一个表达式,eval() 函数将执行表达式。如果参数是Javascript语句,eval()将执行 Javascript 语句。 4.内存泄漏 (一块被分配的内存既不能使用也不能回收,直到浏览器结束) 意外的全局变量、闭包、未清理的dom元素、被遗忘的定时器和回调?。 Vue如何处理: 1.如果在mounted/created 钩子中绑定了DOM/BOM 对象中的事件,需要在beforeDestroy 中做对应解绑处理 5.async、promise区别 async/await是基于Promise实现的,它不能用于普通的回调函数。 promise:then接收resolve(),catch接收reject() Promise.all:是等所有异步操作都完成之后返回结果,相当于让这些异步同步了(如多个await同步执行)。如果没有报错,返回执行结果[res1, res2,...];如果报错,则返回第一个报错的promise的结果 6.bind方法可以让函数想什么时候调用就什么时候调用。apply、call方法只是临时改变了this指向。 7.单例、工厂、观察者项目中实际场景 单例:弹窗,无论点击多少次,弹窗只应该被创建一次;全局缓存、vuex创建全局的store、Redux中的Store 工厂:创建工具库,导出有且只有一个的引用如: jquery 可以使用$, lodash可以使用;类似React.createElement,屏蔽了开发者直接使用new VNode,符合开放封闭原则,VNode的实现对开发者不可见 观察者:onClick的事件绑定、Promise、jQuery.$callBack、NodeJs自定义事件 8.for in? 和object.keys区别 for...in 会遍历继承的原型属性;Object.keys不会遍历继承的原型属性 9.JavaScript有几种类型的值 栈:原始数据类型(Undefined ?Null ?Boolean ?Number ?String)ps:栈存放指针 堆:引用数据类型(对象、数组、函数) 10.双问号操作符 a ?? b等同于 a !== undefined && a !== null ? a : b 参考:2021年前端最新最全面试题(答案持续更新中~) - 良人非良 - 博客园 设计模式:JavaScript中常见的十五种设计模式 - -渔人码头- - 博客园 css1. :root { --main-bg-color: coral; }//没有引号 #div1 { background-color: var(--main-bg-color); } 业务 1.openlayers WMS服务:Web Map Service,网络地图服务,它是利用具有地理空间位置信息的数据制作地图,其中将地图定义为地理数据的可视化表现,能够根据用户的请求,返回相应的地图(返回服务级元数据、返回一个地图影像、返回显示在地图上的某些特殊要素的信息、返回地图的图例信息) (OpenGIS Web Map Title Service)WMTS牺牲了提供定制地图的灵活性,代之以通过提供静态数据(基础地图)来增强伸缩性,这些静态数据的范围框和比例尺被限定在各个图块内. 网络要素服务(WFS)支持用户在分布式的环境下通过HTTP对地理要素进行插入,更新,删除,检索和发现服务。WFS通过OGC Filter构造查询条件,支持基于空间几何关系的查询,基于属性域的查询,当然还包括基于空间关系和属性域的共同查询。 1)切片方式(TileWMS):动态地图在GIS Server生成后,以切片的方式返回到前端,优点是将地图切分,每个切片的数据量很小,便于数据的传输,适用于网络状况不佳的环境;缺点是在地图切片的过程中,可能会造成我遇到的 标注多次出现的问题。 ?2)图像方式(ImageWMS):地图生成后,直接以一个整体返回到前端显示,优点是不会出现标注重复出现的问题,确定是对网络状况不佳的环境,可能出现请求失败的问题。 |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/12 23:04:43- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |