探索Vue.js component内容实现


Posted in Javascript onNovember 03, 2016

现在来系统地学习一下Vue(参考vue.js官方文档):

Vue.js是一个构建数据驱动的web界面的库,其目标是实现响应的数据绑定组合的试图组件

Vue.js拥抱数据驱动的视图概念,这意味着我们能在普通的HTML模板中使用特殊的用法将DOM“绑定”到底层数据。一旦创建了绑定,DOM将于数据保持同步。

探索Vue.js component内容实现

以下参考代码与上面的模型相对应

<!-- 这是我们的 View -->
<div id="example-1">
   Hello {{ name }}!
</div>
// 这是我们的 Model
var exampleData = {
   name: 'Vue.js'
}
 
// 创建一个 Vue 实例或 "ViewModel"
// 它连接 View 与 Model
var exampleVM = new Vue({
   el: '#example-1',  // 在一个id为'example-1'的实体上挂载
   data: exampleData  // 数据流
})

通常我们会把Model写在Vue实例当中,下面写法与上面写法效果一样:

<!-- 这是我们的 View -->
<div id="example-1">
   Hello {{ name }}!  <!--- Vue的数据模型用{{datamodel}}包裹起来 --->
</div>
 
// 创建一个 Vue 实例或 "ViewModel"
// 它连接 View 与 Model<br><script>
var exampleVM = new Vue({
   el: '#example-1',  // 在一个id为'example-1'的实体上挂载
   data: {
       name: 'Vue.js'
      } // 数据流
})<br></script>

这样一段程序执行后,在#example-1这个控件中就会显示‘Hello Vue.js!'。

下面来看看指令(Directives):
指令是特殊的带有前缀 v- 的特性,指令的值限定为绑定表达式,比如一个if的指令:

<p v-if="greeting">hello!<p>

还有绑定指令,即将某些属性值与一些值相绑定,比如:

<input :type = "questItem.type", :name = "questItem.name"/>

这里省略了“v-bind”,使得input的属性值赋值具有“计算”的效果。 

计算属性

这里介绍一下$watch的用法,用于当一个数据需要根据其他的数据而变化时的情况:

<script><br>var vm = new Vue({
 el: '#demo',
 data: {
  firstName: 'Foo',
  lastName: 'Bar',
  fullName: 'Foo Bar'
 }
})<br></script>
 
vm.$watch('firstName', function (val) { // 当firstname改变时,立马更新vm.fullname
 this.fullName = val + ' ' + this.lastName
})
 
vm.$watch('lastName', function (val) {  // 当lastname改变时,立马更新vm.fullname
 this.fullName = this.firstName + ' ' + val
})

在这里,所有的数据的对象都可以通过vm.firstname等来访问。

 

v-model

顾名思义,就是Vue当中的数据模型,它用来绑定Vue实例中的数据:

<!--- bi-direction bound --->
<div id="app">
  <p>{{message}}</p>
  <input v-model="message"> <!--Model,input输入的数据会立即反馈到Vue实例中--> 
</div>
<script>
  new Vue({
    el: '#app',  // View
    data: {
      message: 'Hello Vue.js'
    }
  })
</script>

比如要用来绑定一个表单控件,就是把选择的值显示出来:

<!---    表单控件绑定-单选 --->
<div id="myselect">  // 外面这一层我一开始没有加,然后就出错了,el好像一般是挂载在<div>构件上
<select v-model="selected"> // data的数据类型是selected,值是选取的值
  <option seleceted>A</option>
  <option>B</option>
  <option>C</option>
</select>
<span>Selected: {{ selected }}</span>
</div>
 
<script>
  new Vue({
    el: '#myselect',
    data:{
      selected:[]
    }
  })
</script>

v-if, v-else   

这个指令可以用的很灵活,比如我在表单中生成新题目,有“单选题”、“多选题”、“文本题”三种,那么针对不同的题目应该显示的控件有所不同,这时可以使用如下语法:

<div v-if="questItem.type === 'textarea'"> // 注意是三个等号
    <textarea></textarea>
</div>
<div v=else>
    <div></div>
</div>
 

v-for

这个用于对数组元素的遍历,举个例子: 

<ul id="demo">
  <li
    v-for="item in items"
    class="item-{{$index}}">  <!--- $index指的是当前数组元素在数组中的位置 --->
    {{parentMessage}} - {{$index}} - {{item.message}} <!--一个view结构-->
  </li>
</ul>
<button id="btn1">点击我</button>
<script>
  var demo= new Vue({
    el: '#demo',
    data:{
      parentMessage: 'Parent',
      items:[
        {message: 'Foo'},
        {message: 'Bar'}
      ]
    }
  })
</script>

以上代码的意思是遍历demo实例中的items数组,将里面的每一个数组元素('Foo','Bar')分别在<li>标签中显示出来

为了避免对整个列表进行渲染,经常会使用:track-by = "$index",表示只对当前数组元素进行操作。

至此,关于Vue的最基本的东西已经介绍完,需要更多的API资料可以参考: http://cn.vuejs.org/api/ 

Vue文件的结构以及数据流的控制

在vue文件中,我们经常可以看到这样的格式:

<template>
    <div> </div>
</template>
 
<script>
    export default{
       data(){ ...
       },
       methods:{ // 自定义方法,可对data进行处理
          method1(){ ... }
          ...     
       },
       components: { ... }
       vuex: {
          getters:{ // 获取store的数据
            questionnaire: state => state.currentQuestionnaire
          }
          actions: { //用来分发数据容器store中mutations方法
            action1(){ dispatch("SET_QUEST", item) } // dispatch用来调用父组件store的"SET_QUEST"方法
            action2(){ ... }
       } 
       directives: {
          'my-directive': {
            bind: function(){ //钩子函数,只调用一次,在指令第一次绑定到元素上时调用 }
            update: function(newValue, oldValue) { //钩子函数,在bind之后以初始值为参数第一次调用,之后每当绑定至变化时调用 }
            unbind: function(){ //钩子函数,只调用一次,在指令从元素上解绑时调用 }
          }
       }  




// 自定义指令,在<template>中以<div v-my-directives = ""> 方式调用    
     }
</script>
 
<style>  </style>

<template>中放置的是这个页面(或者页面的一部分)所拥有的控件,而<script>中定义的是Vue的数据对象和方法,<style>中定义的是控件的css样式。

在methods中经常使用到“this”关键字,该关键字指向Vue组件实例。

event.target: 触发事件的具体控件,不产生冒泡作用,是谁就是谁,这个在锁定事件触发的控件时经常用到,比如:

<div @click.stop = "addItem($event)">
   <span data-type = "radio">单选题</span>
   <span data-type = "checkbox">多选题</span>
   <span data-type = "textarea">文本题</span>
</div>
 
<script>
   export default{
      method: {
          addItem(event){
             let target = event.target
             if(target.nodeName.toLowerCase() === 'span') { // 当点击了选择的按钮后
                this.showMask = true  // 显示弹出框
                this.questItem.type = target.dataset.type  // 设置问题的类型
             }
      }
   }
</script>

最后讲讲this.$els: 一个对象,包含注册有v-el的DOM元素

<div class = "promt-header">
  <div>
     <label> 问题名称: </label>
     <input type = "text", placeholder = "请输入标题" v-el: item-title/>
  </div>
</div>
<div class = "promt-footer" @click.stop = "handleInput(&event)">
   <button type = "button" data-operation = "confirm"> 确定 </button>
   <button type = "button" data-operation = "cancel"> 取消 </button>
</div>
 
<script>
   methods: {
        handleInput(event) {
          let target = event.target
          if(target.nodeName.toLowerCase() !== 'button') {
            return
          }
          let itemTitle = this.$els.itemTitle
          let itemSelections = this.$els.itemSelections
          if(target.dataset.operation === "confirm") {
            if(this.questItem.type === "textarea") {
              this.addTextarea(itemTitle)
            } else {
              this.addSelections(itemTitle, itemSelections)
            }
          } else {
            this.handleCancel()
          }
        },
   }
</script>

上面的代码是不完整的,但是可以看到,v-el把该控件挂载在一个名字为"item-title"的实体中,我们可以通过this.$els.itemTitle将其提取出来

要使用该控件的属性值(输入值),可以这样:

this.$els.itemTitle.value

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js DOM的学习笔记
Dec 22 Javascript
jQuery中size()方法用法实例
Dec 27 Javascript
javascript html5 canvas实现可拖动省份的中国地图
Mar 11 Javascript
BOM系列第一篇之定时器setTimeout和setInterval
Aug 17 Javascript
Javascript中apply、call、bind的巧妙使用
Aug 18 Javascript
MvcPager分页控件 适用于Bootstrap
Jun 03 Javascript
利用JS对iframe父子(内外)页面进行操作的方法教程
Jun 15 Javascript
jquery.pagination.js分页使用教程
Oct 23 jQuery
从0到1构建vueSSR项目之node以及vue-cli3的配置
Mar 07 Javascript
js 根据对象数组中的属性进行排序实现代码
Sep 12 Javascript
如何正确理解vue中的key详解
Nov 02 Javascript
详解为什么Vue中的v-if和v-for不建议一起用
Jan 13 Vue.js
javascript跨域请求包装函数与用法示例
Nov 03 #Javascript
预防网页挂马的方法总结
Nov 03 #Javascript
网页挂马方式整理及详细介绍
Nov 03 #Javascript
AngularJS实现在ng-Options加上index的解决方法
Nov 03 #Javascript
AngularJS验证信息框架的封装插件用法【w5cValidator扩展插件】
Nov 03 #Javascript
基于vuejs+webpack的日期选择插件
May 21 #Javascript
Vue.js创建Calendar日历效果
Nov 03 #Javascript
You might like
如何限制访问者的ip(PHPBB的代码)
2006/10/09 PHP
PHP SEO优化之URL优化方法
2011/04/21 PHP
php设计模式 Builder(建造者模式)
2011/06/26 PHP
PHP实现对png图像进行缩放的方法(支持透明背景)
2015/07/15 PHP
PHP利用超级全局变量$_POST来接收表单数据的实例
2016/11/05 PHP
PHP超级全局变量【$GLOBALS,$_SERVER,$_REQUEST等】用法实例分析
2019/12/11 PHP
张孝祥JavaScript学习阶段性总结(2)--(X)HTML学习
2007/02/03 Javascript
前淘宝前端开发工程师阿当的PPT中有JS技术理念问题
2010/01/15 Javascript
基于jquery的Repeater实现代码
2010/07/17 Javascript
JavaScript高级程序设计 阅读笔记(七) ECMAScript中的语句
2012/02/27 Javascript
js中关于一个分号的崩溃示例
2013/11/11 Javascript
简述jQuery ajax的执行顺序
2016/01/05 Javascript
Easyui 之 Treegrid 笔记
2016/04/29 Javascript
JS遍历对象属性的方法示例
2017/01/10 Javascript
ES6生成器用法实例分析
2017/04/10 Javascript
Angular中的$watch、$watchGroup、$watchCollection
2017/06/25 Javascript
Vue.js移动端左滑删除组件的实现代码
2017/09/08 Javascript
JS+CSS实现网页加载中的动画效果
2017/10/27 Javascript
vue.js数据绑定操作详解
2018/04/23 Javascript
使用django-suit为django 1.7 admin后台添加模板
2014/11/18 Python
Python列出一个文件夹及其子目录的所有文件
2016/06/30 Python
使用python Fabric动态修改远程机器hosts的方法
2018/10/26 Python
python tkinter 设置窗口大小不可缩放实例
2020/03/04 Python
利用CSS3的border-radius绘制太极及爱心图案示例
2016/05/17 HTML / CSS
详解Canvas事件绑定
2018/06/27 HTML / CSS
英国灯具和灯泡网上商店:Lights.co.uk
2018/02/02 全球购物
会计学财务管理专业个人的自我评价
2013/10/19 职场文书
教师专业理论水平的自我评价分享
2013/11/09 职场文书
计算机专业毕业生自我鉴定
2014/01/16 职场文书
教师年度考核自我鉴定
2014/01/19 职场文书
招聘专员岗位职责
2014/03/07 职场文书
乡镇三严三实学习心得体会
2014/10/13 职场文书
2014年除四害工作总结
2014/12/06 职场文书
学校推普周活动总结
2015/05/07 职场文书
python实现局部图像放大
2021/11/17 Python
使用MybatisPlus打印sql语句
2022/04/22 SQL Server