话说过完年回来,仿佛一夜之间身边的人都在谈论 Vue,相关的组件也如雨后春笋一般涌现出来,比如大名鼎鼎的 Element UI、iView 还有不久前刚发布的 ATUI,这些组件库虽然实现方式和接口格式有所不同,但大都界面美观,体验流畅,可以说和 Vue 框架提供的良好性能是密不可分的。
Vue 是一个上手简单,却富有内涵的框架,既可以像使用 jQuery 一样简单地通过 扩展名为 vue 的文件会被打包工具编译成标准 js 文件以供浏览器执行,在编译时 模板的内容会被转换为 render 函数,换句话说 的内容只是一个配置参数,Vue 通过这种类似于 HTML 的结构来生成渲染方法,最后通过执行渲染方法来初始化一个真正的页面。当然对于复杂的需求我们也可以不用模板,直接编写 render 函数。 类似的还有 data 属性,我们通常使用这样的格式来定义 data。 事实上这只是一个配置选项,编译时 Vue 会根据我们传入的选项来生成真正的 data 实例,其中的每个属性都绑定了 getter、setter 方法,具备响应式特性。这就是为什么需要显式的定义 data 属性。 默认情况下 data 内的属性会被 Vue 实例代理(Vue 实例的同名属性指向 data 对象的属性),如果某些属性不想被 Vue 代理可以在属性名称前面加上 '$' 或 '_' ,这样就只能通过 Vue.$data._someProp 来访问。 在实例化一个 Vue 对象时会经历那些阶段呢?通俗的说会有两个阶段:一是生成 data,二是挂载 template,也就是 MVVM 中的 VM(view-model)。 生成 data 被称作 create,挂载 template 被称作 mount,两个阶段的前后分别对应着两组生命周期节点,也就是 beforeCreate、created 以及 beforeMound、mounded。 有生则有灭,销毁响应式属性,解除绑定事件的过程被称作 destroy,前后也分别对应着 beforeDestroy 和 destroyed 节点。 响应式属性的变化会触发视图的更新,这个更新的过程被称作 update,前后自然也对应着 beforeUpdate、updated 两个节点。数据与视图绑定是 VM 框架提供的核心功能,也正是所谓的数据驱动,数据驱动和事件驱动的差异有点类似于查询和中断的区别。 组件是一个封闭的环境,除非通过生命周期节点来探测,不然操作内部数据的进度是无法获知的,换句话说我们从组件外部访问 data 数据时,无法确定它是更新前还是更新后的,尤其在通过异步方式请求后端数据时,这个问题就更加明显。因此官方不建议通过 $parent、$children 或 $refs 等方式强行获取数据,而是建议在数据状态可控时通过事件触发来回传数据($emit、$on)。 大胡子语法(双大括号)可以方便的在 HTML 元素内部(innerHTML)插入文本。 设置模板标签属性可以直接用 的格式书写,如果需要为属性绑定变量或表达式则需使用 v-bind 指令:,没错,冒号 ':' 正是 v-bind 指令的缩写,等同于 ,有时我们需要绑定数值(Number),而非内容为数字的字符串,v-bind 指令恰好可以区分两者。 另一个支持缩写的指令是 v-on ,可以用 '@' 表示,比如 ,指令较多时,缩写可以使代码更清晰。 控制流程的指令包括:v-if、v-else、v-else-if 和 v-for。 计算属性可以用于筛选或格式化数据,比如当后端返回时间戳时,我们可通过计算属性获取指定格式的日期时间。 如何响应式更新 data 中的数组? 我们修改了其中的某一项,并通过下面的方式更新到数组中: 我们会发现,表格中显示的数据并没有改变,这是因为直接对数组中的元素赋值不会触发Vue的响应式更新,为了解决 Js 语言特性的限制,Vue 提供了一种变通的方法,可以使用 push()、pop()、shift() 等函数来修改数组。 除此之外我们也可以通过 Vue.set() 函数修改数组,比如: 通过 v-model 指令为表单元素绑定数据 表单元素不但可以显示数据也可以修改数据,我们当然可以通过 :value="data" 来显示数据,并且通过 @input="data=$event.target.value" 来修改数据,不过 Vue 为我们提供了一个更简洁的语法糖,直接使用 v-model="data" 即可同时实现两者的功能。 其实,对于任何自定义组件只要我们实现了 value 属性和 input 事件都可以使用 v-model 指令进行数据绑定。如果实现了 change 事件也可以配合 v-model.lazy 来调用。 (未完待续...)data() { return {
commonData,
layout, isShow: true, isLoading: false
};
} {{ status ? '有效' : '无效' }} // 后端发送的数据
requireddata: {cityId: 3}
// 模板绑定的数据// 判断单行或多行文本框// v-for 除了可以生成列表,还可以用于通过 JSON 动态生成模板let formConfig = [{ type: 'singleLine', name: 'userName'},{ type: 'singleLine', name: 'birthday'},{ type: 'multiLine', name: 'comment'}]
data() { return { updateTime: 1490526754
}
}
computed: { timeString: {
get () { // Js默认以毫秒为单位,需要进行转换
let timeStamp = new Date(this.updateTime * 1000) return timeStamp.toLocaleString()
},
set (val) { let timeStamp = Math.round(Date.getTime() / 1000) this.updateTime = val || timeStamp
}
}
}
有时我们需要在数据表格组件中显示一组数据,后端返回给我们一个 JSON 数组:let modifiedRow = {id: 2, name: frank, age: 20}// 视图未发生更新this.dataSource[1] = modifiedRow// 视图响应式更新dataSource.splice(1, 1, modifiedRow)
Vue.set(dataSource, 1, modifiedRow)
// ex-input.vue...
data() { return { // 获取表单初始值
editValue: this.value
}
},prop: { // 定义value属性
value:[String, Number]
},watch: { // 观察并同步value属性
value(val) { this.editValue = val
}
},methods: {
handelInput (event) { this.editValue = event.target.value // 实现input事件
this.$emit('input', this.editValue)
}
}
...// 两者是等价的,显然 v-model 更简洁一些
作者:OSIMLY
链接:https://www.jianshu.com/p/1fcc2988b725



