您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
三六零分类信息网 > 伊犁哈萨克分类信息网,免费分类信息发布

vue组建与路由使用总结

2025/8/21 8:57:06发布5次查看
这次给大家带来vue组建与路由使用总结,vue组建与路由使用的注意事项有哪些,下面就是实战案例,一起来看一下。
1、组件三种挂载方式
自动挂载
var app3 = new vue({  el: '#app-3',  data: {  seen: true  } })
手动挂载
// 可以实现延迟按需挂载 <p id="app"> {{name}} </p>  <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的p(忽略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触发的时机:
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
vue-cli+webpack创建项目报错
jquery fullpage插件如何操作头部与尾部
以上就是vue组建与路由使用总结的详细内容。
伊犁哈萨克分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product