一、条件控制指令
1、v-if,条件渲染

<div id="J_app">
  <p v-if="show">显示该标签</p>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    show: true
  }
})

2、template使用
template元素最终不会出现在dom中

<div id="J_app">
  <template v-if="isdisplay">
    <h1>模板标签会隐藏</h1>
    <p>模板标签会隐藏</p>
    <p>模板标签会隐藏</p>
  </template>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    isdisplay: true
  }
})

3、v-else使用

<div id="J_app">
  <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>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    type: 'D'
  }
})

4、数据遗留

<div id="J_app">
  <template v-if="loginType === 'username'">
    <label>Username</label>
    <input placeholder="Enter your username">
  </template>
  <template v-else>
    <label>Email</label>
    <input placeholder="Enter your email address">
  </template>
</div>

5、数据不遗留

<div id="J_app">
  <template v-if="loginType === 'username'">
    <label>Username</label>
    <input placeholder="Enter your username" key="username-input">
  </template>
  <template v-else>
    <label>Email</label>
    <input placeholder="Enter your email address" key="email-input">
  </template>
</div>

6、v-show,条件展示

<div id="J_app">
  <p v-show="isdisplay">只是做了隐藏,元素本身没有从dom上消失</p>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    isdisplay: true
  }
})

v-show不支持template,也不支持v-else,通过是否添加display:none控制显隐,v-if的切换开销比较大。

二、循环控制指令
1、固定值

<div id="J_app">
  <span v-for="i in 10"> {{ i }} </span>
</div>

2、template使用

<div id="J_app">
  <ul>
    <template v-for="item in items">
      <li>{{ item.option }}</li>
      <li class="divider"></li>
    </template>
  </ul>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    items: [
      { option: '前进' },
      { option: '后退' },
      { option: '休息' }
    ]
  }
})

3、遍历数组

<div id="J_app">
  <ol>
    <li v-for="item in items" :key="item.id">
      {{ item.text }}
    </li>
  </ol>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    items: [
      { text: '学习 webpack' },
      { text: '学习 Vue' },
      { text: '整个牛项目' }
    ]
  }
})
<div id="J_app">
  <ol>
    <li v-for="(item,index) in items">
      {{ flag }} - {{ item.index }} - {{ item.text }}
    </li>
  </ol>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    flag: "parent",
    items: [
      { text: '学习 webpack' },
      { text: '学习 Vue' },
      { text: '整个牛项目' }
    ]
  }
})
//改变原数组,数组变异
vapp.items.push({text:'学习es6'})
//返回新数组
vapp.items = vapp.items.filter(function (item) {
  return item.text.match(/学习/)
})
//修改某项
Vue.set(vapp.items, 2, { text: '学习vue,需要基础知识做铺垫'})
<div id="J_app">
  <ol>
    <li v-for="num in evenNumbers"> {{ num }} </li>
  </ol>
</div>
//显示数组过滤的副本,而不改变原来的数组
var vapp = new Vue({
  el: '#J_app',
  data: {
      numbers: [ 1, 2, 3, 4, 5 ]
  },
  computed: {
      evenNumbers: function () {
        return this.numbers.filter(function (number) {
          return number % 2 === 0
        })
      }
    }
})
<div id="J_app">
  <ol>
    <li v-for="num in even(numbers)"> {{ num }} </li>
  </ol>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
      numbers: [ 1, 2, 3, 4, 5 ]
  },
  methods: {
      even: function (numbers) {
        return numbers.filter(function (number) {
          return number % 2 === 0
        })
      }
   }
})

4、遍历对象

<ul id="J_app">
  <li v-for="value in personObj"> {{ value }} </li>
</ul>
var vapp = new Vue({
  el: '#J_app',
  data: {
    personObj: {
      firstName: 'Camille',
      lastName: 'Hou',
      age: 30
    }
  }
})
//添加sex属性到personObj对象
Vue.set(vapp.personObj,'sex','male')
//也可以用
vapp.$set(vapp.personObj,'sex','male')
//为已有对象赋予多个属性值
vapp.personObj = Object.assign({}, vapp.personObj, {
  weight: 105,
  len: '158cm'
})
<div id="J_app">
  <div v-for="(value, key) in personObj">
    {{ key }}:{{ value }}
  </div>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    personObj: {
      firstName: 'Camille',
      lastName: 'Hou',
      age: 30
    }
  }
})
<div id="J_app">
  <div v-for="(value, key, index) in personObj">
    {{ index }}、{{ key }}、{{ value }}
  </div>
</div>
var vapp = new Vue({
  el: '#J_app',
  data: {
    personObj: {
      firstName: 'Camille',
      lastName: 'Hou',
      age: 30
    }
  }
})

vue中的dom指令控制的更多相关文章

  1. Vue中获取dom元素

    Vue.js虽然说是数据驱动页面的,但是有时候我们也要获取dom对象进行一些操作. vue的不同版本获取dom对象的方法不一样 Vue.js  1.0版本中,通过v-el绑定,然后通过this.els ...

  2. 第七十六篇:ref引用(在vue中引用Dom的方法)

    好家伙, 引子: jQuery简化了程序员操作DOM的过程 vue 优势:MVVM 在vue中,程序员不需要操作DOM.程序员只需要把数据维护好即可!(数据驱动视图) 那么若要在vue中操作dom,这 ...

  3. vue中常见的指令

    1,差值表达式{{}} <p >{{ msg }}</p> 2.v-cloak解决差值表达式闪烁的问题 <p v-cloak>{{ msg }}</p> ...

  4. [记录] Vue中的dom操作

    使用过Vue的同学都应该有这样一个感觉,在vue中页面是基于数据驱动的,不需要我们自己操作dom,框架帮我们完成了这一步,事实上Vue官方也建议我们这样做 在绝大多数情况下是不需要操作dom就可以完成 ...

  5. 在vue中创建自定义指令

    原文:https://dev.to/ratracegrad/creating-custom-directives-in-vue-58hh 翻译:心上有杨 指令是带有 v- 前缀的特殊属性.指令的作用是 ...

  6. Vue中v-on的指令以及一些其他指令

    1.v-on的基本使用 <div id="app"> <!-- 使用事件绑定的简写形式 --> <input type="button&qu ...

  7. Vue中 等待DOM或者数据完成 在执行 --this.$nextTick()

    虽然 Vue.js 通常鼓励开发人员沿着“数据驱动”的方式思考,避免直接接触 DOM,但是有时我们确实要这么做.比如一个新闻滚动的列表项.如果在这里需要操作dom, 应该是等待 Vue 完成更新 DO ...

  8. 在vue中操作dom元素

    在vue中可以通过给标签加ref属性,就可以在js中利用ref去引用它,从而达到操作该dom元素,以下是个参考例子 1 <template> 2 <div> 3 <div ...

  9. vue中操作Dom节点的方法

    1.vue中ref操作dom节点 <template> <div id="app"> <div </div> <button @cl ...

随机推荐

  1. 零基础http代理http完美代理访问

    如果翻过墙,或者做过渗透啥的,肯定对代理不陌生,说白了,代理服务器就是一个中转站,你对目标网址的请求都会进过代理服务器去请求,类似于一个被你操控的傀儡,别人能知道的也只能是这个代理,从而提升安全性和访 ...

  2. Linux内核调试 - 一般人儿我都不告诉他(一)【转】

    转自:http://www.cnblogs.com/armlinux/archive/2011/04/14/2396821.html 悄悄地进入Linux内核调试(一) 本文基址:http://blo ...

  3. 《TCP/IP 详解 卷1:协议》第 3 章:链路层

    在体系结构中,我们知道:链路层(或数据链路层)包含为共享相同介质的邻居建立连接的协议和方法,同时,设计链路层的目的是为 IP 模块发送和接受 IP 数据报,链路层可用于携带支持 IP 的辅助性协议,例 ...

  4. android getActivity.findViewById获取ListView 返回NULL

    在控件ID正确的情况下,检查是否在实例化布局文件之后,获取LISTVIEW, 先inflate找layout下布局文件,并实例化后才能获得Listview的ID demo: public class ...

  5. javascript 类型比较方法

    不要使用new Number().new Boolean().new String()创建包装对象: 用parseInt()或parseFloat()来转换任意类型到number: 用String() ...

  6. Fragment的详细使用

    一直在用Fragment,但是没有系统的整理过,Google了一下相关文章,看到了几篇,将几篇还不错的文章重点整理了下,很多是直接Copy的,只为做个笔记,以后翻来看比较方便,建议大家看一下下面几篇, ...

  7. CNN中各种各样的卷积

    https://zhuanlan.zhihu.com/p/29367273 https://zhuanlan.zhihu.com/p/28749411 以及1*1卷积核:https://www.zhi ...

  8. Spatial Transformer Networks

    参考:http://blog.csdn.net/xbinworld/article/details/69049680 论文的关键在理解这句话: 先通过V中坐标(xtarget,ytarget)以此找到 ...

  9. eclipse安装主题插件(Color Theme)

    点击“Help”--> Install New Software Name:ColorThemeLocation:http://eclipse-color-theme.github.io/upd ...

  10. 树链剖分边权模板spoj375

    树链剖分是树分解成多条链来解决树上两点之间的路径上的问题 如何求出树链:第一次dfs求出树上每个结点的大小和深度和最大的儿子,第二次dfs就能将最大的儿子串起来并hash(映射)到线段树上(或者其他数 ...