VUE重点问题总结


Posted in Javascript onMarch 19, 2018

1、组件三种挂载方式

自动挂载

var app3 = new Vue({
 el: '#app-3',
 data: {
 seen: true
 }
})

手动挂载

// 可以实现延迟按需挂载
<div id="app"> {{name}} </div> 
<button onclick="test()">挂载</button> 
<script> 
 var obj= {name: '张三'} 
 var vm = new Vue({ 
 data: obj
 }) 
 function test() { 
 vm.$mount("#app"); 
 }
// Vue.extend()创建没有挂载的的子类,可以使用该子累创建多个实例
var app= Vue.extend({ 
 template: '<p>{{message}}</p>', 
 data: function () { 
 return { 
  message: 'message'
  } 
 } 
 }) 
 new app().$mount('#app') // 创建 app实例,并挂载到一个元素上

2、路由传递参数的方式

<p>
  <!-- query要用path来引入,params要用name来引入,故不能写为 :to="{path:'/login',params: {isLogin: true}} -->
  <!-- 跳转路由时用this.$router: this.$router.push({name:"login",params:{isLogin:true}});this.$router.push({path: '/login', query: {isLogin : true}}); -->
  <!-- 接收参数时用this.$route: this.$route.query.isLogin 和 this.$route.params.isLogin; -->
  <router-link :to="{name:'login',params: {isLogin: true}}">亲,请登录</router-link>
  <router-link :to="{name:'login',params: {isLogin: false}}">免费注册</router-link>
 </p>
 <!-- 路由出口, 路由匹配到的组件将渲染在这里 -->
 <router-view></router-view>

3、对render:h => h(App)的理解

render:h=>h(App)是ES6中的箭头函数写法,等价于render:function(h){return h(App);}.

1.箭头函数中的this是 指向 包裹this所在函数外面的对象上。

2.h是creatElement的别名,vue生态系统的通用管理

3.template:‘<app/>',components:{App}配合使用与单独使用render:h=>h(App)会达到同样的效果

前者识别<template>标签,后者直接解析template下的id为app的div(忽略template的存在)

new Vue({
 el: '#app', // 相当于 new Vue({}).$mount('#app');
 template: '<App/>', // 1、可以通过在 #app 内加入<app></app>替代 2、或者 通过 render: h => h(App) 渲染一个视图,然后提供给el挂载
 components: { // vue2中可以通过 render: h => h(App) 渲染一个视图,然后提供给el挂载
  App
 }
});

4、Vue.nextTick()的理解

与DOM相关操作写在该函数回调中,确保DOM已渲染

nextTick的由来:

由于VUE的数据驱动视图更新,是异步的,即修改数据的当下,视图不会立刻更新,而是等同一事件循环中的所有数据变化完成之后,再统一进行视图更新。

nextTick的触发时机:

在同一事件循环中的数据变化后,DOM完成更新,立即执行nextTick(callback)内的回调。

应用场景:

需要在视图更新之后,基于新的视图进行操作。

在Vue生命周期的created()钩子函数进行的DOM操作一定要放在Vue.nextTick()的回调函数中。原因是什么呢,原因是在created()钩子函数执行的时候DOM 其实并未进行任何渲染,而此时进行DOM操作无异于徒劳,所以此处一定要将DOM操作的js代码放进Vue.nextTick()的回调函数中。与之对应的就是mounted钩子函数,因为该钩子函数执行时所有的DOM挂载和渲染都已完成,此时在该钩子函数中进行任何DOM操作都不会有问题 。

在数据变化后要执行的某个操作,而这个操作需要使用随数据改变而改变的DOM结构的时候,这个操作都应该放进Vue.nextTick()的回调函数中。

简单总结事件循环:

同步代码执行 -> 查找异步队列,推入执行栈,执行callback1[事件循环1] ->查找异步队列,推入执行栈,执行callback2[事件循环2]...即每个异步callback,最终都会形成自己独立的一个事件循环。结合nextTick的由来,可以推出每个事件循环中,nextTick触发的时机:

Javascript 相关文章推荐
Javascript 文件夹选择框的两种解决方案
Jul 01 Javascript
js实现点击后将文字或图片复制到剪贴板的方法
Aug 04 Javascript
JavaScript判断undefined类型的正确方法
Jun 30 Javascript
js获取html的span标签的值方法(超简单)
Jul 26 Javascript
Javascript 获取鼠标当前的位置实现方法
Oct 27 Javascript
ajax与json 获取数据并在前台使用简单实例
Jan 19 Javascript
angularjs下ng-repeat点击元素改变样式的实现方法
Sep 12 Javascript
vue自定义指令之面板拖拽的实现
Apr 14 Javascript
基于JavaScript 实现拖放功能
Sep 12 Javascript
如何用JS模拟实现数组的map方法
Jul 30 Javascript
JS实现拖动模糊框特效
Aug 25 Javascript
详解uniapp的全局变量实现方式
Jan 11 Javascript
p5.js入门教程之键盘交互
Mar 19 #Javascript
vue 实现的树形菜的实例代码
Mar 19 #Javascript
Servlet3.0与纯javascript通过Ajax交互的实例详解
Mar 18 #Javascript
jQuery替换节点元素的操作方法
Mar 18 #jQuery
使用Angular CLI生成 Angular 5项目教程详解
Mar 18 #Javascript
分析javascript原型及原型链
Mar 18 #Javascript
jquery 实现拖动文件上传加载进度条功能
Mar 18 #jQuery
You might like
神族 Protoss 剧情介绍
2020/03/14 星际争霸
轻松入门: 煮好咖啡的七个诀窍
2021/03/03 冲泡冲煮
PHP 图片水印类代码
2012/08/27 PHP
学习php中的正则表达式
2014/08/17 PHP
php 数组随机取值的简单实例
2016/05/23 PHP
ThinkPHP5.0框架验证码功能实现方法【基于第三方扩展包】
2019/03/11 PHP
一些Javascript的IE和Firefox(火狐)兼容性的问题总结及常用例子
2009/05/21 Javascript
Javascript在IE或Firefox下获取鼠标位置的代码
2009/12/18 Javascript
javascript学习笔记(十七) 检测浏览器插件代码
2012/06/20 Javascript
JavaScript控制Session操作方法
2013/01/17 Javascript
用JavaScript实现动画效果的方法
2013/07/20 Javascript
用javascript将数据导入Excel示例代码
2014/09/10 Javascript
js实现跨域的方法实例详解
2015/06/24 Javascript
js 弹出对话框(遮罩)透明,可拖动的简单实例
2016/07/11 Javascript
jquery实现简单的瀑布流布局
2016/12/11 Javascript
Javascript中的神器——Promise
2017/02/08 Javascript
react-router browserHistory刷新页面404问题解决方法
2017/12/29 Javascript
Angular7中创建组件/自定义指令/管道的方法实例详解
2019/04/02 Javascript
微信小程序获取复选框全选反选选中的值(实例代码)
2019/12/17 Javascript
在Python程序中操作文件之flush()方法的使用教程
2015/05/24 Python
python构建深度神经网络(DNN)
2018/03/10 Python
Pandas Shift函数的基础入门学习笔记
2018/11/16 Python
使用python PIL库实现简单验证码的去噪方法步骤
2019/05/10 Python
如何安装并在pycharm使用selenium的方法
2020/04/30 Python
如何在python中实现线性回归
2020/08/10 Python
Camille Jewelry官网:现代女性时尚首饰
2019/07/07 全球购物
Nobody Denim官网:购买高级女士牛仔裤
2021/03/15 全球购物
不用游标的SQL语句有哪些
2012/09/07 面试题
国际经济贸易专业推荐信
2013/11/06 职场文书
煤矿机修工岗位职责
2014/02/07 职场文书
中学生运动会入场词
2014/02/12 职场文书
小学六年级学生评语
2014/04/22 职场文书
企业精神口号
2014/06/11 职场文书
埃及王子观后感
2015/06/16 职场文书
预防职务犯罪警示教育心得体会
2016/01/15 职场文书
如何书写读后感?(附范文)
2019/07/26 职场文书