02、Vue 常见指令


版权声明:本文为博主原创文章,未经博主允许不得转载

PS:转载请注明出处
作者: TigerChain
本文出自 TigerChain 手把手教Vue

教程简介

  • 1、阅读对象
    本篇教程适合新手阅读,老手直接略过
  • 2、教程难度
    初级,本人水平有限,文章内容难免会出现问题,如果有问题欢迎指出,谢谢

正文

一、Vue 的实例

通过上节课,我们知道如何引入 Vue 来工作,初学者不建议使用 vue-cli 来创建项目,在这里我们使用引入 script 来编写 Vue demo

Vue 完全可以看作是面向对象的语言,我们创建一个 Vue 的实例一般是这样做的

var vm = new Vue({
  // 数据
  data:{
  },
  methods:{
      // 方法
  },
  等等其它 
})

我们可以看到 – data 作为属性、methods 作为方法,new Vue 就是一个实例对象,这样理解 Vue 就会很轻松「如果有面向对象的基础」

二、什么是指令

传统意义上的指令就是指挥机器工作的指示和命令,vue 中的指令一般是以 v- 开头

vue 中的指令的职责是,当表达式的值改变时,会响应式的对 DOM 产生影响

在开始指令之前,我们先来一个 helloWorld 来直观的感受下下 Vue 吧

1、先来一个 HelloWorld

在这里我使用 atom 来开发

1、新建一个目录,并且导入 vue.js 如下

2、打开 index.html,输入以下内容

<h3>Vue 的指令</h3>
<hr style="height:2px;border:none;border-top:2px dashed #0066CC;"  />
<ol>
   <li><a href="./instructions/hello.html">Hello World</a></li>
</ol>

以上是核心代码,body 中的代码「没有写 html 标准模版代码,完整的可以看 index.html界面」

3、在 js 目录下引入 vue.js 文件「在官方上下载」

4、在 instructions 目录下新建 hello.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Vue--hello world</title>
  <script src="../js/vue.js"></script>
</head>
<body>
  <div id="container">{{msg}}</div>

  <script>
    var vm = new Vue({
      el:'#container',
      data:{
        msg:'hello world'
      }
    })
  </script>
</body>
</html>

5、查看一下结果吧,这里我们使用 browser-sync 来启动一个服务「帮你解决手动刷新的困扰,看过我 react 系列的应该非常熟悉」,这里不过多介绍 browser-sync , 了解更多请查看官网:http://www.browsersync.cn

打开命令行,在根目录下输入

vue-study/vue-lesson/01、基本指令 // 在当前目录
▶ browser-sync start --server --files "**/*.css, **/*.html"

就会自动打开默认浏览器,然后界面就出来了,往后你修改的内容,不用 F5 不用刷新,内容自动就同步了「真 TM 帅」

看到了吧,输入命令以后就会自动打开浏览器容器,并且显示 index.html 的内容,我们也正确的看到了 hello world 的内容「使用 vue 创建的」

二、v-on,v-if,v-for 指令

1、v-on 是用来监管 DOM 事件的,并执行一些 js 代码,比如点击事件,提交事件等

用法

v-on:click="表达式"

废话不多说直接上例子吧

  • 1、在 instructions 下新建 v-on.html,然后在 index.html 中引入

先看 index.html 中修改「见下面红色框」

{% asset_img add_v_on_html.png index.html 中添加 v-on.html %}
  • 2、v-on.html 给出 body 中的核心代码「html 基本模版和 vue.js 引信省略」
<body>
  <div id="container">
    <!--这里添加 v-on:click 然后定义一个方法-->
    <input type="button" value="点我" v-on:click="clickme()"/>
    <p>{{num}}</p>
  </div>

  <script>
    var vm = new Vue({
      el:"#container",
      data:{
        // 定义一个数据默认是1
        num:1
      },
      // 方法写在 methods 关建字中,从字名看里面可以多个方法
      methods:{
           // 这里就是 v-onclick:后面跟的方法
        clickme:function(){
          // this 指的是当前对象 -- vm
          this.num++
        }
      }
    })
  </script>
</body>
  • 3、这样一个简单的 v-on:click 指令就可以使用了,我们来看一下结果

PS: v-on 的缩写

<!-- 完整语法 -->
<a v-on:click="doSomething">...</a>

<!-- 缩写 -->
<a @click="doSomething">...</a>

2、v-if 和 v-for 指令

v-if 是条件判断,v-for 是用来循环数据的,从名字就可以看出来

v-if 的模版

<div v-if="type === 'A'">
  A
</div>
<div v-else-if="type === 'B'">
  B
</div>
<div v-else-if="type === 'C'">
  C
</div>
<div v-else>
  Not A/B/C
</div>

其中 v-else-if 和 v-else 不是必须的「根据实际情况看是否需要」

v-for 的模版

<标签 v-for="item in imtes">
    {{item}}
</标签>

比如:遍历 li  假设有一个数组 items=[{"message":"hello"},"message":"vue"]
<ul id="container">
  <li v-for="item in items">
    {{ item.message }}
  </li>
</ul>

如果想要使用 v-for 来遍历带索引使用

v-for="(item,index) in items"

其中 index 就是索引,如果想使用索引的话就可以使用此种方式

这里的标签指的需要循环的标签,好了不多说了,直接看例子吧,下面我们实现一个下面的例子

{% asset_img v-if_v-for.gif v-if 和 v-for 指令 %}

我们使用 v-if 来判断需要显示方形按钮/div 还是圆形按钮/div ,并且使用 v-for 遍历了两个数组「分别使用 ul 和 table 样式显示」

核心代码

<div id="container">
      <h3>1、使用 v-if 来切换按钮上的文字和 div 的显示样式</h3>
      <button v-on:click="cheangeDiv()" style="width:100px;">{{theWord}}</button>
      <!--  如果 flag 为 true 的话那么就显示 div -->
      <div v-if="flag" >
        <div id="showDiv">
            我显示出来了
        </div>
      </div>
      <!-- 否则显示圆形的 div -->
      <div v-else>
        <div id="showBuleDiv"><span style="color:white">哈哈</span></div>
      </div>
   <hr>
   <h3>2、使用 v-for 来循环数组</h3>

    <span>列举出你喜欢吃的水果</span><br/>
    我喜欢吃的水果有
    <ul>
      <li v-for="item in fruit">
        <span>{{item}}</span>
      </li>
    </ul>

  <h3> 3、使用 v-for 循环输出 以下 json 串</h3>
  <p>
    mydatas:[
      {"name":"TigerChain","age":"保密","address":"地球中国","lover":"不告诉你"},
      {"name":"张三","age":"23","address":"地球中国","lover":"打游戏"},
      {"name":"李四","age":"25","address":"地球中国","lover":"读书"},
      {"name":"王五","age":"30","address":"是中唯一不下雪的地方","lover":"写代码"},
      {"name":"赵六","age":"18","address":"中国北京","lover":"写博客"},
      {"name":"钱七","age":"27","address":"中国陕西","lover":"做菜"}
    ]
  </p>
    <table border="1">
      <tr>
        <th>序号</th>
        <th>姓名</th>
        <th>年龄</th>
        <th>地址</th>
        <th>爱好</th>
      </tr>
      <tr v-for="(item,index) in mydatas">
        <!-- 其中 index 是索引,也就是数组的角标 -->
        <td><span>{{index}}</span></td>
        <td><span>{{item.name}}</span></td>
        <td><span>{{item.age}}</span></td>
        <td><span>{{item.address}}</span></td>
        <td><span>{{item.lover}}</span></td>
      </tr>
    </table>
  </div>

  <script>
    var vm = new Vue({
      el:'#container',
      // 数据
      data:{
        theWord:"圆形",
        flag:false,
        msg:'show me',
        mydatas:[
          {"name":"TigerChain","age":"保密","address":"地球中国","lover":"不告诉你"},
          {"name":"张三","age":"23","address":"地球中国","lover":"打游戏"},
          {"name":"李四","age":"25","address":"地球中国","lover":"读书"},
          {"name":"王五","age":"30","address":"是中唯一不下雪的地方","lover":"写代码"},
          {"name":"赵六","age":"18","address":"中国北京","lover":"写博客"},
          {"name":"钱七","age":"27","address":"中国陕西","lover":"做菜"}
        ],
        fruit:["苹果","香蕉","葡萄","美国香瓜"]

      },
      // 方法
      methods:{
        // 切换 div
        cheangeDiv(){
          this.flag = !this.flag;
          if(this.theWord =="圆形"){
            this.theWord = "方形"
          }else{
            this.theWord = "圆形"
          }
        }
      }
    })
  </script>

具体代码可以查看 https://github.com/githubchen001/vue-lesson 中的基本指令章节

3、v-show 和 v-model

v-show

在前面我们使用了 v-if 指令,v-show 的指令和 v-if 类似,基本模版是:

<标签 v-show="条件">如果达到条件要显示的内容</标签>

比如:我们有一个按钮点击显示或隐藏 div 如下效果

{% asset_img v-show.gif v-show 效果 %}

核心代码:

<div id="container">
  <button @click="clickMe()">{{defaultButton}}</button>
  <!-- 如果 v-show = true 的话就会显示 此 div  -->
  <div v-show="flag" id="showDiv">
    <span>我是 v-show</span>
  </div>
</div>

<script>
  var vm = new Vue({
    el:'#container',
    data:{
      // 是否显示 div 的标志,默认是不显示
      flag:false,
      // 默认按钮显示字样
      defaultButton:'显示'
    },
    methods:{
      // 按钮点击的方法
      clickMe(){
        if(this.defaultButton == "显示"){
          this.defaultButton ="隐藏"
        }else{
          this.defaultButton ="显示"
        }
        this.flag = !this.flag
      }
    }
  })
</script>

从上面的例子中,我们可以感受到 v-show 的用法了

v-model

v-modle 体现了 mvvm 设计思想,它是一个双向数据绑定「在 input 和 textarea 上」

我们直接在上面 id 为 container 的 div 中添加如下代码

<input type="text" v-model="itext" class="myinput"> <br/>
你输入的值是:<font class="myfont">{{itext}}</font>

并且我们在 data 中定义一个 itext 属性

data:{
  // 是否显示 div 的标志,默认是不显示
  flag:false,
  // 默认按钮显示字样
  defaultButton:'显示',
  // 新添加的属性
  itext: ''
},

运行查看结果:

从上面的结果中我们可以看到,当我们给 input 中输入文本的时候就下面就会自动的显示出所对应的文本,并且点击按钮的时候改变文本的值,输入框中的值会自动改变,这就是双向绑定

三、来个 blog 实例

1、经过上面我们学习了几个指令,我们来写一个综合的小案例,效果如下:

2、开始撸码「在这里我们给出核心代码」,后面会放出 demo 地址

我们在 instructions 目录下新建一个 blog-demo.html 文件

  • 1、首先我们在这里要引入一个 sweetalert2.js 来做弹出框
  • 2、我们来看看 div 中的内容
  <div id="container">
    <p>标题:<input type="text" v-model="title" placeholder="标题" ></p>
    <p>内容:<textarea name="content" id="" cols="30" rows="10" v-model="content"></textarea></p>
    <p><input type="submit" value="添加" v-on:click="add" ></p>

    <hr>

    <table border="1">
      <tr>
        <th>序号</th>
        <th>标题</th>
        <th>内容</th>
        <th>操作</th>
      </tr>
      <!-- 遍历把内容显示出来 -->
      <tr v-for="(data,index) in datas">
        <td>{{index+1}}</td>
        <td>{{data.title}}</td>
        <td>{{data.content}}</td>
        <td>
          <a href="#" v-on:click="deleteRow(index)">删除</a>
          <a href="#" v-on:click="modifyData(index)">修改</a>
        </td>
      </tr>
    </table>
    <span v-show="datas.length!=0" ><a href="#" v-on:click="deleteAllData()">全部删除</a></span>
    <!-- 没有数据的显示这个标签 -->
    <span v-show="datas.length==0">没有数据</span>
  </div>

以上我们定义了一个 blog 的模版,下面我们给它添加一些操作功能

  • 3、添加 script 代码

从上面的代码中,我们看到了 v-modle,v-show ,v-for 等指令,下面我们来看看 vue 中的代码

<script>
var vm = new Vue({
  el:'#container',
  data:{
    // 标题
    title:'',
    // 内容
    content:'',
    // 所有的内容
    datas:[]
  },
  methods:{
    // 添加数据
    add(){
      if(this.title =="" || this.content==""){
        alert("标题或内容不能为空")
        return
      }
      // 把标题和内容添加到数组中
      this.datas.push({"title":this.title,"content":this.content})
      // 添加完数据以后把标题和内容置空
      this.title=""
      this.content=""
    },
    // 删除数据
    deleteRow(index){
      //在一个方法中调用
      let that = this // 由于是在方法的方法内部,this 就指的是当前方法了, 所以要使用 var that = this 来声明一下
     //在一个方法中调用 另一个方法
     this.$options.methods.deleteMethod(function callback(){
         that.datas.splice(index,1)
     })
    },
    //修改数据
    modifyData(index){
      // 取得原来的数据
      let data = this.datas[index]

      swal({
        title: '修改',
        // type: 'info',
        html:
          "<div><p>标题:<input id=\"title\" value="+data.title+" ></input></p>"+
          " <p>内容:<input  id=\"content\" value="+data.content+"></input></p></div>" ,

        showCancelButton: true,
        focusConfirm: false,
        confirmButtonText:'确定',
        cancelButtonText:'取消'
      }).then((result)=>{
        if(result.value){
          let title = document.getElementById('title').value
          let content = document.getElementById('content').value
          // 修改数据
          this.datas.splice(index,1,{"title":title,"content":content})
        }
      })
    },
    //删除 全部数据
    deleteAllData(){
      //这里使用箭头函数就不用再使用 let that = this 来转化了,可以上面的比较一下,两种方式
     this.$options.methods.deleteMethod(()=>{
       this.datas = []
     })
    },
    // 封装一个删除方法
    deleteMethod(callback){
      swal({
        title: '确定删除吗?',
        text: "全部删除了以后就不恢复不了哦!",
        type: 'warning',
        showCancelButton: true,
        confirmButtonColor: '#3085d6',
        cancelButtonColor: '#d33',
        cancelButtonText:'取消',
        confirmButtonText: '确定删除!'
      }).then((result) => {
        if (result.value) {
           callback()
        }
      })
    }
  }
})
</script>

以上就是 blog-demo 的核心代码,注释的非常清楚,这里不过多解释了,请自行实践

到此为止,我们就把 vue 的几个常用的指令说完了

四、总结

通过这节,我们学习了 vue 的几个常见的指令,并且写了一个小 demo ,通过动手就能直观的感受到 vue 指令的作用

作者: TigerChain 公号同名,订阅查看更多内容

本文出自 TigerChain 手把手教Vue

我将源码发布到了 手把手教 Vue 方便大家查看,欢迎大家 fork,喜欢的话给个 star

阅读原文


交个朋友

如果觉得本篇对你有帮助,那么请你完成以下几件小事情

1、动动你的小手关注一下以下公众号「TigerChain」查看更多精彩分享

2、更多视频关注的我的 B站:https://space.bilibili.com/44242327/


文章作者: TigerChain
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 TigerChain !
评论
  目录