zoukankan      html  css  js  c++  java
  • 【转】Vue v-bind与v-model的区别

    v-model 指令在表单控件元素上创建双向数据绑定,所谓双向绑定,指的就是我们在js中的vue实例中

    的data与其渲染的dom元素上的内容保持一致,两者无论谁被改变,另一方也会相应的更新为相同的数据

    最基础的就是实现一个联动的效果

     

    vue v-bind绑定属性和样式

    这期跟大家分享的,是v-bind指令。它可以往元素的属性中绑定数据,也可以动态地根据数据为元素绑定不同的样式。

    绑定属性

    最简单的例子,我们有一张图片,需要定义图片的src。我们可以直接在元素的属性里面定义:

    <div id="app">
        <img src="https://cn.vuejs.org/images/logo.png" alt="">
    </div>
    
    <!-- ... ... -->
    
    <script type="text/javascript">
        var app = new Vue({
            el: '#app'
        });
    </script>

    但是在实际工作中,我们通常会遇到的情况是,图片地址是从数据里返回的,这个时候v-bind指令就派上了用场。当然,我们可以同时绑定各种属性:

    <div id="app">
        <img v-bind:src="imgSrc" v-bind:alt="imgAlt" v-bind:title="imgTitle">
    </div>
    
    <!-- ... ... -->
    
    <script type="text/javascript">
        var app = new Vue({
            el: '#app',
            data: {
                imgSrc: 'https://cn.vuejs.org/images/logo.png',
                imgAlt: 'vue-logo',
                imgTitle: '这是你指定的title,主人'
            }
        });
    </script>

    在浏览器可以看到效果:

    这时候你也许会说,每次都要写一遍v-bind好麻烦。没问题,Vue为你准备好了简写的方式:

    <div id="app">
        <img :src="imgSrc" :alt="imgAlt" :title="imgTitle">
    </div>

    绑定行内样式

    v-bind也可以用于绑定样式,使用行内样式时,关键字是style,跟在html里面直接写行内样式类似。注意样式的写法跟css会有些许不同,横杠分词变成驼峰式分词。

    <div id="app">
        <button class="btn" :style="{ color: 'white', backgroundColor: 'blue' }">点击我吧,主人!</button>
    </div>

    当然,把样式写在vue的data里面会方便一些:

    <div id="app">
        <button class="btn" :style="styles">点击我吧,主人!</button>
    </div>
    
    <!-- ... ... -->
    
    <script type="text/javascript">
        var app = new Vue({
            el: '#app',
            data: {
                styles: {
                    color: 'white',
                    backgroundColor: 'blue'
                }
            }
        });
    </script>

    在浏览器中可以看到html中的行内样式:

    绑定CSS样式

    更常见的做法肯定是根据数据绑定不同的样式了。这时关键字是class。【注意:v-bind:class指令可以与普通的class特性共存】

    <style>
        .is-active {
            color: white;
            background-color: green;
        }
    </style>
    
    <body>
        <div id="app">
            <!-- 根据数据中isActive来决定是否把is-active这个class加给元素 -->
            <button class="btn" :class="{ 'is-active': isActive }">点击我吧,主人!</button>
        </div>
    
        <!-- ... ... -->
    
        <script type="text/javascript">
            var app = new Vue({
                el: '#app',
                data: {
                    isActive: true
                }
            });
        </script>
    </body>

    效果如图:

    当然,在实际工作中isActive的值一般不会像例子中这样直接写死,而是根据用户的交互或者数据进行判断。

    传递静态或动态 Prop

    像这样,你已经知道了可以像这样给 prop 传入一个静态的值:

    <blog-post title="My journey with Vue"></blog-post>

    你也知道 prop 可以通过 v-bind 动态赋值,例如:

    <!-- 动态赋予一个变量的值 -->
    <blog-post v-bind:title="post.title"></blog-post>
    
    <!-- 动态赋予一个复杂表达式的值 -->
    <blog-post
      v-bind:title="post.title + ' by ' + post.author.name"
    ></blog-post>
  • 相关阅读:
    Open-E DSS V7 应用系列之 9 主动/主动 iSCSI群集部署
    Open-E DSS V7 应用系列 7~8
    Open-E DSS V7 应用系列之4~6
    Open-E DSS V7 应用系列之1~3
    kbmmw 5.18.0 发布
    Spring笔记--@ConditionalOnBean坑
    Kafka 3.0新特性
    如何让Git记住你的GitHub Token,避免每次都要重复输入?
    特征值和特征向量到底是个啥?能做什么用?
    ICCV 2021 | BN-NAS: 只训练BN层来自动搜索模型
  • 原文地址:https://www.cnblogs.com/yoyo008/p/10728791.html
Copyright © 2011-2022 走看看