Vue 使用技巧手记
watch监听
Vue监听属性有很多种写法,也有几个配置选项
使用配置项
new Vue({
watch:{
content:{
handler(old,newVal){
console.log(old,newVal)
},
deep:true,
immediate:true
}
}
})
- deep:是一个布尔类型,告诉Vue以递归的方式监听嵌套对象内部值的变化。
- immediate:是一个布尔值类型,会立即触发而调用处理函数,而不用等到属性值第一次发生变化时才调用。
以上两个值默认值都为false,不需要的时候完全可以忽略。使用下面这种方法。
new Vue({
watch:{
content(old,newVal){
console.log(old,newVal)
}
}
})
或者还可以这样写
new Vue({
watch:{
content:"watchContent"
},
methods:{
watchContent(val,oldVal){
console.log(val,oldVal)
}
}
})
在使用immediate的时候,由于是自动触发,这样会导致旧值为undefined,这一点需要格外注意。
component 使用
在做项目中,可能会有一些情况,比如:弹窗里面可能有很多东西,这样的话需要写N个弹窗来支撑业务,否则就需要把所有的组件全部写在一个弹窗里面,但是这样会造成代码的混乱。
解决方案:
abc.vue
<template>
<div>
我是 abc
</div>
</template>
app.vue
<template>
<alert v-if="componentName">
<component :is=" 'q-'+componentName "/>
</alert>
</template>
<script>
export default {
data(){
return {
componentName:null
}
}
}
</script>
组件内model属性
Vue 2.2.0推出model属性用来让使用者在组件中自定义触发v-model的触发时机,在没有推出该api之前默认使用input事件触发v-model更新。
官网解释:
允许一个自定义组件在使用v-model时定制prop和event。默认情况下,一个组件上的v-model会把value用作prop且把input用作event,但是一些输入类型比如单选框和复选框按钮可能想使用value prop来达到不同的目的。使用model选项可以回避这些情况产生的冲突。
实例:
children:
export default {
/**
* 自定义v-model
*/
model: {
// v-model默认绑定的值
prop: "modelList",
// 当组件使用v-model的使用使用change事件触发,原来没有更改的使用使用input事件触发
event: "change"
},
props:{
modelList:{
type:Array,
default:() => []
}
},
methods:{
changeModel(){
let newList = [1,2,3];
this.$emit("change", changeModel);
}
}
}
parent
<template>
<children v-model="newList"/>
</template>
export default {
data(){
return {
newList:[]
}
},
watch:{
newList:{
handler(old,newVal){
console.log(old,newVal)
},
deep:true
}
}
}
大致使用就是这样,当Children组件遇到this.$emit("change")事件时候,会把接收到的参数,通过v-model实现数据绑定。
全局方法以及插件编写
在vue中拓展自己的插件供项目使用。
myGlobalMethod .js
export default {
install(Vue, options) {
Vue.myGlobalMethod = function () { // 1. 添加全局方法或属性,如: vue-custom-element
// 逻辑...
}
Vue.directive('my-directive', { // 2. 添加全局资源:指令/过滤器/过渡等,如 vue-touch
bind (el, binding, vnode, oldVnode) {
// 逻辑...
}
...
})
Vue.mixin({
created () { // 3. 通过全局 mixin方法添加一些组件选项,如: vuex
// 逻辑...
}
...
})
Vue.prototype.$myMethod = function (options) { // 4. 添加实例方法,通过把它们添加到 Vue.prototype 上实现
// 逻辑...
}
}
}
main.js
import Vue from "vue";
import myGlobalMethod from "./plugin/myGlobalMethod.js";
Vue.use(myGlobalMethod);
this.$myMethod();
函数式组件
函数式组件是无状态的,而且不能使用this,因此render函数获得了一个新的context上下文参数,包含prop,事件监听,字内容,插槽以及一些其他数据。
export default {
functional:true,
render(h,{props,children}){
return h(`h${props.livel}`,children)
}
}
可以使用模板的functional替换掉functional:true。
<template functional>
<div>{{props.message}}</div>
</template>
Vue 使用技巧手记的更多相关文章
- vue的技巧代码
转载:https://segmentfault.com/a/1190000014085613 第一招:化繁为简的Watchers 场景还原: created(){ this.fetchPostList ...
- vue小技巧之偷懒的文件路径——减少不必要的代码
众所周知,我们写vue项目的时候都会创建很多个文件,尤其是一些中大型项目,会有很深的文件夹,当你去引入的时候,要写很长的路径比如我要引入一个css文件, 必须得 import '../../../s ...
- vue 使用技巧总结 18.11
前言: 在大概学完 vue 整体框架后,有幸接触到花裤衩大神写的 vue-elementUI-admin 模板框架,把这个模板框架当作 demo,跟着 code 一遍,最大的收获是在以逻辑简单的模板熟 ...
- Vue 开发技巧或者说Vue知识点梳理(转,自个学习)
Vue 组件通讯 ——常见使用场景可以分为三类: 父子通信: 父向子传递数据是通过 props,子向父是通过 events($emit):通过父链 / 子链也可以通信($parent / $child ...
- Vue 开发技巧总结
博客地址:https://ainyi.com/95 本人玩了 Vue 两年多,在此总结一下开发时的一些技巧和方法 自定义组件 v-model v-model 是 Vue 提供的一个语法糖,它本质上是 ...
- vue使用技巧(分页、nextTick、复制对象)
分页技巧 v1.0+ 版本的时候使用过滤器 limitBy 实现 v2.0+ 版本的时候使用compute使用 slice 方法实现 data:{ pageNum:10 }, computed:{ n ...
- Vue小技巧-懒加载
Vue懒加载包括图片懒加载与路由懒加载 1.图片懒加载: 首先安装 vue-lazyload包 然后导入并加载事先下载好的加载图片 import VueLazyLoad from 'vue-lazyl ...
- 教你一个vue小技巧,一般人我不说的
本文由云+社区发表 1. 需求 最近的项目中,需要实现在vue框架中动态渲染带提示框的单选/多选文本框,具体的效果如下图所示,在输入框聚焦时,前端组件通过接收的kv参数渲染出选项,用户点击选项,可以将 ...
- vue 使用技巧总结 19.01
组件中箭头函数的使用 不要使用箭头来定义任意生命周期钩子函数: 不要使用箭头来定义一个 methods 函数: 不要使用箭头来定义 computed 里的函数: 不要使用箭头定义 watch 里的函数 ...
随机推荐
- @Conditional 和 @ConditionalOnProperty
@ConditionalOnProperty https://blog.csdn.net/dalangzhonghangxing/article/details/78420057 @Condition ...
- 开启Nginx监控 with-http_stub_status_module
1.开启监控with-http_stub_status_module ./configure --with-openssl=/usr/local/ssl --with-http_stub_stat ...
- PLSQL Developer连接远程oracle配置(详细解读)
转自:https://blog.csdn.net/zhige_j/article/details/80832654 一.安装Instant Client 1. 下载Instant Client(轻量级 ...
- 【LeetCode算法-26】Remove Duplicates from Sorted Array
LeetCode第26题 Given a sorted array nums, remove the duplicates in-place such that each element appear ...
- SqlServer Stuff
SqlServer Stuff DECLARE @TAB TABLE ( UserID INT, UserName ) ) INSERT INTO @TAB ( UserID, UserName ) ...
- 应用程序正常初始化(0xc0000135)失败。请单击“确定”,终止应用程序。
应用程序正常初始化(0xc0000135)失败.请单击“确定”,终止应用程序. 没有安装对应版本的.NET FRAMEWORK.
- java的字节码bytecode
字节码名字的由来 字节码以一个字节即8bit为最小单位储存:字节码是java程序编译后的结果:字节码是一组8位字节为基础单位的二进制流 Java从源文件到执行的过程. 如何阅读JAVA字节码
- pcl使用入门
最近在学习pcl,C++早就忘记了,所以踩了好些坑 不过终于通过了,特此记录下来 环境:win7+pcl1.81+vs2015 1.安装pcl1.81 下载PCL-1.8.1-AllInOne-msv ...
- NOI2019 Fe
NFLS XY NOI2019 Fe Orz zsy,zhf,wqy,zjc,bly! Goodbye OI!
- iOS:Xcode代码块,提升敲代码的效率
一.代码块在哪里? 看下图 或者 快捷键:command+shift+L 长这样: 二.如何创建代码块: 1.先选中要创建的代码片段,然后点击右键,选中 Create Code Snippet 然后会 ...