vue随记
(一)使用props传值:
<HeadTitle name-data="100"></HeadTitle>
props:['nameData']
父组件传递复合名称数据时使用小写和中划线(-) 组合,子组件接收复合名称数据时使用小驼峰。
(二)路由去 “#”
路由配置:
mode:'history'
(三)路由跳转后回到页面的顶部
路由配置:
scrollBehavior () {
return { x: 0, y: 0 }
}
(四)重定向
‘重定向’指,用户访问 '/a' 路径时,url会被替换成 '/b' 。
{
path:'/a',
redirect:'/b'
}
重定向至某个子路由:
{
path:'/list',
name:'list'
children:[
{
path:'/list',
redirect:'aa',
},
{
path:'aa',
name:'a',
component:A
},
{
path:'bb',
name:'b',
component:B
}
]
}
(五)watch监控复合数据下面的某个属性
data(){
return{
opt:{
a:1,
b:'abc'
}
}
}
watch:{
"opt.b"(){
// code
},
"$route"(){
// 路由监控
}
}
(六)watch深层监控
watch:{
name:{
handler(){
// code
},
deep:true
}
}
(七)vue兼容IE
因为Vue使用了ES6 Promise,而IE浏览器不支持,解决方法是: 使用babel-polyfill转换
$ npm install --save-dev babel-polyfill
如果使用vue-cli项目,在build/webpack.base.js中添加:
require('babel-polyfill');
entry: { app: ['babel-polyfill','./src/main.js'] },
(八)watch的简便写法
组件创建的时获取一次列表,同时监听data中数据变化,每当发生变化的时候重新获取一次筛选后的列表。
常规写法:
data(){ // data
return{
list:[1,2,3]
}
},
methods:{
editList(){ // 定义对list数据处理的方法。
// 编辑list
}
},
created(){ // 组件创建时处理list数据
this.editList();
},
watch:{
list:{ // 监控list变化重新编辑一次处理list
handler(){
this.editList();
}
}
}
优化写法:
data(){ // data
return{
list:[1,2,3]
}
},
methods:{
editList(){
// 编辑list
}
},
watch:{
list:{ // 首先,在watchers中,可以直接使用函数的字面量名称;其次,声明immediate:true表示创建组件时立马执行一次。
handler:"editList", // 直接使用函数的字面量名称
immediate:true // 表示创建组件时立马执行一次,即:created时期执行一次
}
}
(九)页面加载完成立即执行事件
data(){
list:[]
},
watch:{
"list"(){
this.$nextTick(){
// DOM更新完成,执行事件
}
}
}
(十)set / delete
1、对vue中复合数据 [ Array || Object ] 的设置做到响应使用vue内置方法set
this.$set(目标数据,键名,键值) / Vue.set(目标数据,键名,键值);
键名存在就修改,不存在就添加。
2、删除vue中复合数据中的某个值
Vue.delete(目标数据,健名) / this.$delete(目标数据,健名) ;
(十一)v-cloak vue隐藏元素直至当前实例准备完成才编译
这个指令保持在元素上直到关联实例结束编译。需配合CSS使用
css:
[v-cloak] {
display: none;
}
template:
<div v-cloak>
{{ message }}
</div>
<!--当前div内对vue的编译会等到实例准备完成后开始-->
(十二)vue-cli打包上线
(十三)路由别名
‘别名’指,用户访问 '/b' 路径时,url依旧是 '/b' ,但匹配到的视图是 '/a' 路由的匹配视图,如同访问 '/a' 路由一样。
{
path:'/a',
alias:'/b'
}
(十四)数据还原状态
1、初始化时设置的数据:
data(){
num:1,
list:[],
opt:{}
}
2、经过处理后数据 this.num,this.list,this.opt 状态
3、使用初始化状态的数据
可使用 this.$options.data() 拿到最初的状态。
示例: Object.assign( this.form , this.$options.data().form );
(十五)在vue-cli项目中使用markdown编辑器:Vue-SimpleMDE
1、npm install vue-simplemde --save
2、// 全局引用
(十六)$nextTick
1、$nextTick(() => {}) 与DOM相关操作写在该函数回调中,确保DOM已渲染。
2、在created()钩子函数进行DOM操作一定要放在Vue.nextTick()的回调函数中。(原因:在created()执行时DOM 其实并未进行任何渲染,此时进行DOM操作是获取不到DOM元素,所以一定要将DOM操作的代码放进Vue.nextTick()的回调函数中,确保此时DOM已渲染。)
vue随记的更多相关文章
- Vue折腾记 - (3)写一个不大靠谱的typeahead组件
Vue折腾记 - (3)写一个不大靠谱的typeahead组件 2017年07月20日 15:17:05 阅读数:691 前言 typeahead在网站中的应用很多..今天跟着我来写一个不大靠谱的ty ...
- Vue折腾记 - (2)写一个不大靠谱的面包屑组件
先看效果图 我把页面标题和面包屑封装到一起..就不用涉及到组件的通讯了,不然又要去监听路由或者依赖状态去获取 这里写图片描述 疑惑解答: 点击父(也就是折叠菜单)为什么会跑到子菜单第一个 因为我第一个 ...
- vue项目中路由验证和相应拦截的使用
详解Vue路由钩子及应用场景(小结):https://www.jb51.net/article/127678.htm vue项目中路由验证和相应拦截的使用:https://blog.csdn.net/ ...
- WEB前端学习资源清单
常用学习资源 JS参考与基础学习系列 [MDN]JS标准参考 es6教程 JS标准参考教程 编程类中文书籍索引 深入理解JS系列 前端开发仓库 <JavaScript 闯关记> JavaS ...
- [转] WEB前端学习资源清单
常用学习资源 JS参考与基础学习系列 [MDN]JS标准参考 es6教程 JS标准参考教程 编程类中文书籍索引 深入理解JS系列 前端开发仓库 <JavaScript 闯关记> JavaS ...
- Javascript的学习清单
Javascript的学习清单 Javascript学习资源 程序员必读书籍 深入理解JavaScript系列 es6教程 jQuery中文文档 vue官网 zeptojs中文版 常用的插件与UI组件 ...
- vue踩坑记
vue踩坑记 易错点 语法好难啊qwq 不要把'data'写成'date' 在v-html/v-bind中使用vue变量时不需要加变量名 在非vue事件中使用vue中变量时需要加变量名 正确 < ...
- 【转】Vue 脱坑记 - 查漏补缺(汇总下群里高频询问的xxx及给出不靠谱的解决方案)
前言 文章内容覆盖范围,芝麻绿豆的破问题都有,不止于vue; 给出的是方案,但不是手把手一字一句的给你说十万个为什么! 有三类人不适合此篇文章: “喜欢站在道德制高点的圣母婊” – 适合去教堂 “无理 ...
- Vue 脱坑记
问题汇总 Q:安装超时(install timeout) 方案有这么些: cnpm : 国内对npm的镜像版本 /* cnpm website: https://npm.taobao.org/ */ ...
随机推荐
- 并发编程——synchronized关键字的使用
前言 我们一般对共享数据操作的时候,为了达到线程安全我们会使用synchronized关键字去修饰方法或者代码块.那么今天我们就来讲一讲synchronized关键字的使用. 专栏推荐: 并发编程专栏 ...
- linux copy_id
ssh-keygen 产生公钥与私钥对. ssh-copy-id 将本机的公钥复制到远程机器的authorized_keys文件中,ssh-copy-id也能让你有到远程机器的home, ~./ssh ...
- 在包一级定制log4j日志输出
软件开发和维护过程中,日志是必不可少的工具,对于一个10万行规模的产品,要分析它的某一部分,最简单的方法是将log4j配置文件的rootLogger的输出级别设置为debug,但这样将使产品的所有部分 ...
- Linux远程访问控制
目录 一.SSH远程管理 1.1.定义 1.2.配置OpenSSH服务端 二.sshd服务支持两种验证方式 2.1.密码验证 2.2.使用SSH客户端程序 ssh远程登录 scp远程复制 sftp安全 ...
- 【Java】jeesite初始配置以及代码生成工具的使用
jeesite简单使用 首先去技术服务与支持.版本区别一览表 - JeeSite 4.x找到源码下载的部分 JeeSite 源码下载:https://gitee.com/thinkgem/jeesit ...
- 手把手和你一起实现一个Web框架实战——EzWeb框架(四)[Go语言笔记]Go项目实战
手把手和你一起实现一个Web框架实战--EzWeb框架(四)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 这一篇文章主要实现路由组功能.实现路由 ...
- CNVD-2021-14536 锐捷 RG-UAC 统一上网行为管理审计系统信息泄露漏洞
漏洞简介 锐捷 RG-UAC 统一上网行为管理审计系统存在信息泄露,攻击者通过网页源代码可间接获取管理用户账号密码,登录管理后台. 漏洞复现 fofa搜索以下关键字 title="RG-UA ...
- 题解 P3941 入阵曲
题解 观察数据范围,可以 \(\mathcal O(n^2m^2)\) 暴力计算,而加上特殊性质,则可以骗到 \(75pts\) 正解: 我们发现,在一维情况下,\(\mod k\) 相同的前缀和相减 ...
- 题解 P3322 [SDOI2015]排序
题解 仔细审题,我们会发现 小 \(A\) 认为两个操作序列不同,当且仅当操作个数不同,或者至少一个操作不同(种类不同或者操作位置不同). 所以,对于一种操作,不管是交换哪两段,都算作同一种操作,只会 ...
- Nginx 真实的 IP
配置 Nginx 如果你的 Java 项目使用了 Nginx 代理,那么还需要进行以下配置,才能顺利获取到真实的 IP,否则只能获取到 127.0.0.1. 在 Nginx 的配置文件里,找到你 Ja ...