vue单向以及双向数据绑定(v-bind和v-model的使用)

简介: 笔记

准备工作


首先还是创建一个新的页面写入基本代码


v-bind单向绑定


<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>初始vue</title>
    <!-- 引入vue.js -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
    </div>
    <script type="text/javascript">
        // 设置为 false 以阻止 vue 在启动时生成生产提示。
        Vue.config.productionTip = false
    </script>
</body>
</html>

简单写一个输入框绑定

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>初始vue</title>
    <!-- 引入vue.js -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
        单项数据绑定:<input type="text" :value="name">
    </div>
    <script type="text/javascript">
        // 设置为 false 以阻止 vue 在启动时生成生产提示。
        Vue.config.productionTip = false
        new Vue({
            el:'#root',
            data:{
                name:'vue你好!'
            }
        })
    </script>
</body>
</html>

页面长这样40.png

此时我们打开vue开发工具,动态修改name的值,发现页面的值变了

但是如果我们修改输入框的值,开发工具里面的name不会随着输入框改变

41.png

因为v-bind是单向绑定的,想要实现这个功能,我们需要使用双向绑定 v-model

v-model双向绑定


42.png

 <!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>初始vue</title>
    <!-- 引入vue.js -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
        单项数据绑定:<input type="text" v-bind:value="name"><br>
        双项数据绑定:<input type="text" v-model:value="name">
    </div>
    <script type="text/javascript">
        // 设置为 false 以阻止 vue 在启动时生成生产提示。
        Vue.config.productionTip = false
        new Vue({
            el:'#root',
            data:{
                name:'vue你好!'
            }
        })
    </script>
</body>
</html>

通过页面我们可以发现,我们输入框会带着下面的开发工具的值一起改变

43.png

既然双向绑定这么厉害,那么我们是不是可以放弃单向绑定,一直 使用双向绑定呢?


当然是不可以的,我们再看一个例子

首先是单向绑定,没有任何问题

44.png45.png

然后是双向绑定,发现x已经丢了,并且控制台报错了

46.png

模板编译失败,v-model不支持这种类型

47.png

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>初始vue</title>
    <!-- 引入vue.js -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
        单项数据绑定:<input type="text" v-bind:value="name"><br>
        双项数据绑定:<input type="text" v-model:value="name">
        <!-- 如下代码是错误的,因为v-model只能应用在表单(输入类)元素上 必须要有value值 -->
        <h2 v-model:x="name">你好啊!</h2>
    </div>
    <script type="text/javascript">
        // 设置为 false 以阻止 vue 在启动时生成生产提示。
        Vue.config.productionTip = false
        new Vue({
            el:'#root',
            data:{
                name:'vue你好!'
            }
        })
    </script>
</body>
</html>

总结


Vue中有两种绑定方式


1 单项绑定(v-bind):数据只能从data流向页面,可以简写为:

2 双项绑定(v-model):数据不能能从data流向页面,还可以从页面流向data

备注:

1双向绑定一般都应用在表单类元素上(比如input,select,radio等)

2 v-model:value可以简写v-model,因为v-model默认收集的就是value值

单向双向绑定简写如下

      <!-- 简写 -->
        单项数据绑定:<input type="text" :value="name"><br>
        双项数据绑定:<input type="text" v-model="name">
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>初始vue</title>
    <!-- 引入vue.js -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
        <!-- 单项数据绑定:<input type="text" v-bind:value="name"><br>
        双项数据绑定:<input type="text" v-model:value="name"> -->
        <!-- 简写 -->
        单项数据绑定:<input type="text" :value="name"><br>
        双项数据绑定:<input type="text" v-model="name">
        <!-- 如下代码是错误的,因为v-model只能应用在表单(输入类)元素上 必须要有value值 -->
        <!-- <h2 v-model:x="name">你好啊!</h2> -->
    </div>
    <script type="text/javascript">
        // 设置为 false 以阻止 vue 在启动时生成生产提示。
        Vue.config.productionTip = false
        new Vue({
            el:'#root',
            data:{
                name:'vue你好!'
            }
        })
    </script>
</body>
</html>
相关文章
|
2天前
|
JavaScript
vue打印v-model 的值
vue打印v-model 的值
|
2天前
|
JavaScript
Vue实战-组件通信
Vue实战-组件通信
5 0
|
2天前
|
JavaScript
Vue实战-将通用组件注册为全局组件
Vue实战-将通用组件注册为全局组件
5 0
|
3天前
|
JavaScript 前端开发
vue的论坛管理模块-文章评论02
vue的论坛管理模块-文章评论02
|
5月前
|
JavaScript 前端开发 开发者
vue 的双向数据绑定的原理
vue 的双向数据绑定的原理
37 0
|
6月前
|
存储 设计模式 JavaScript
简单小示例彻底搞明白vue双向数据绑定核心原理
vue 很大的一个优势就是双向数据绑定,而在 react 或小程序中是需要我们自己手动 setState、setData 去修改视图数据
51 0
|
JavaScript 前端开发
vue相关面试题2:1.封装vue组件作用;2双向数据绑定原理;3.Router 是什么;4.导航钩子有哪些
它们有以下参数。 ●to::即将要进入的目标路由对象。 ●from:当前导航正要离开的路由。 ●next: 一定要用这个函数才能到达下一个路由,如果不用就会遭到拦截。
233 0
|
3天前
|
JavaScript
VUE里的find与filter使用与区别
VUE里的find与filter使用与区别
12 0
|
3天前
|
JavaScript
vue页面加载时同时请求两个接口
vue页面加载时同时请求两个接口