VUE中v-model和v-for指令详解


Posted in Javascript onJune 23, 2017

1.基本雏形

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <script src="https://unpkg.com/vue/dist/vue.js"></script>
  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        data:{
          msg:'Hello Vue!'
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    {{msg}}
  </div>
</body>
</html>

需要new一个Vue实例,实例化的时候传入了一个对象{el:'#box',data:{msg:'Hello Vue!'}}。这个意思是:Vue这个只控制id="box"这个DIV元素,同时在 HTML模板上使用双花括号{{xxxx}}语法,来访问data中定义的数据。

上面代码我们new处理一个Vue的实例,并赋值给了vm变量,通过这个vm变量,我们也可以访问其中定义的数据:

var vm = new Vue({
        el:'#box',
        data:{
          msg:'Hello Vue!'
        }
      });

      console.log(vm.msg); //'Hello Vue!'

2.v-model指令

所谓的“指令”其实就是扩展了HTML标签功能(属性)。

v-model的双向数据绑定

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <script src="https://unpkg.com/vue/dist/vue.js"></script>
  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        data:{
          msg:'Hello Vue!'
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <input type="text" v-model="msg"/><br/>
    {{msg}} 
  </div>
</body>
</html>

通过v-model 指令,我们把msg 数据绑定到了input文本框,我们修改文本框的值,发现msg 数据改变了。

VUE中v-model和v-for指令详解

注意:如果我们定义的数据是数组或者json,在模板上会怎样显示出来呢?

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <script src="https://unpkg.com/vue/dist/vue.js"></script>
  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        data:{
          msg:'Hello Vue!',
          arr:['apple','banana','orange'],
          json:{a:'apple',b:'banana'}
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <input type="text" v-model="msg"/><br/>
    {{msg}} <br/>
    {{arr}} <br/>
    {{json}}

  </div>
</body>
</html>

数组和json都被当作字符串输出了,显然这不是我们理想的效果。

VUE中v-model和v-for指令详解 

3.v-for指令

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <meta charset="utf-8">
  <script src="http://unpkg.com/vue/dist/vue.js"></script>

  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        data:{
          arr:['apple','banana','orange'],
          json:{a:'apple',b:'banana'}
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <p>循环数组</p>
    <ul>
      <li v-for="a in arr">
      {{a}}
      </li>
    </ul>
    <hr>
    <p>循环出数组索引</p>
    <ul>
      <li v-for="(v,k) in arr">
      {{v}}==>{{k}}
    </ul>
    <p>循环json</p>
    <ul>
      <li v-for="item in json">{{item}}</li>
    </ul>
    <p>循环json的键</p>
    <ul>
      <li v-for="(k,v) in json">
      {{k}}==>{{v}}
      </li>
    </ul>
  </div>
</body>
</html>

VUE中v-model和v-for指令详解

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

Javascript 相关文章推荐
一个刚完成的layout(拖动流畅,不受iframe影响)
Aug 17 Javascript
node+express+jade制作简单网站指南
Nov 26 Javascript
Jquery 实现图片轮换
Jan 28 Javascript
js实现在网页上简单显示时间的方法
Mar 02 Javascript
JavaScript通过function定义对象并给对象添加toString()方法实例分析
Mar 23 Javascript
vue-cli扩展多模块打包的示例代码
Apr 09 Javascript
Vue中控制v-for循环次数的实现方法
Sep 26 Javascript
基于vue的验证码组件的示例代码
Jan 22 Javascript
基于three.js实现的3D粒子动效实例代码
Apr 09 Javascript
vue select 获取value和lable操作
Aug 28 Javascript
jquery实现简易验证插件封装
Sep 13 jQuery
Vue2项目中对百度地图的封装使用详解
Jun 16 Vue.js
JavaScript正则表达式简单实用实例
Jun 23 #Javascript
js中的事件委托或是事件代理使用详解
Jun 23 #Javascript
JS判断非空至少输入两个字符的简单实现方法
Jun 23 #Javascript
详解Vue.js之视图和数据的双向绑定(v-model)
Jun 23 #Javascript
微信小程序组件 marquee实例详解
Jun 23 #Javascript
VUE元素的隐藏和显示(v-show指令)
Jun 23 #Javascript
vue数据双向绑定的注意点
Jun 23 #Javascript
You might like
php的header和asp中的redirect比较
2006/10/09 PHP
使用php shell命令合并图片的代码
2011/06/23 PHP
laravel创建类似ThinPHP中functions.php的全局函数
2016/11/26 PHP
PHP token验证生成原理实例分析
2019/06/05 PHP
鼠标滑过出现预览的大图提示效果
2014/02/26 Javascript
JavaScript跨域调用基于JSON的RESTful API
2016/07/09 Javascript
BootStrap中按钮点击后被禁用按钮的最佳实现方法
2016/09/23 Javascript
js实现简单的计算器功能
2017/01/16 Javascript
BootStrap Validator 根据条件在JS中添加或移除校验操作
2017/10/12 Javascript
详解vue 组件之间使用eventbus传值
2017/10/25 Javascript
详解HTML5 使用video标签实现选择摄像头功能
2017/10/25 Javascript
JavaScript实现的简单Tab点击切换功能示例
2018/07/06 Javascript
Vue文件配置全局变量的实例
2018/09/06 Javascript
使用jQuery动态设置单选框的选中效果
2018/12/06 jQuery
使用VUE+iView+.Net Core上传图片的方法示例
2019/01/04 Javascript
JS前端知识点 运算符优先级,URL编码与解码,String,Math,arguments操作整理总结
2019/06/27 Javascript
微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能
2019/12/06 Javascript
如何实现iframe父子传参通信
2020/02/05 Javascript
vue项目中自定义video视频控制条的实现代码
2020/04/26 Javascript
[00:27]DOTA2次级职业联赛 - Lilith战队宣传片
2014/12/01 DOTA
[01:22:28]DOTA2-DPC中国联赛 正赛 SAG vs RNG BO3 第一场 1月18日
2021/03/11 DOTA
分享6个隐藏的python功能
2017/12/07 Python
python生成lmdb格式的文件实例
2018/11/08 Python
详解pyenv下使用python matplotlib模块的问题解决
2018/11/29 Python
python rsa实现数据加密和解密、签名加密和验签功能
2019/09/18 Python
python利用dlib获取人脸的68个landmark
2019/11/27 Python
Python flask框架实现浏览器点击自定义跳转页面
2020/06/04 Python
Selenium及python实现滚动操作多种方法
2020/07/21 Python
用python进行视频剪辑
2020/11/02 Python
便携式太阳能系统的创新者:GOAL ZERO
2018/02/04 全球购物
贝尔帐篷精品店:Bell Tent Boutique
2019/06/12 全球购物
校园安全检查制度
2014/02/03 职场文书
品牌转让协议书
2014/08/20 职场文书
高中运动会广播稿
2015/08/19 职场文书
创业计划书之外语培训班
2019/11/02 职场文书
解决hive中导入text文件遇到的坑
2021/04/07 Python