您现在的位置:首页 >> 前端 >> 内容

Vue由单个复选框引发的联想

时间:2017/8/4 11:24:42 点击:

  核心提示:关于复选框,我想只要会点html的,大多数会用,但今天在Vue的实例中遇到一个小小的问题引发了我的思考。在此我先把Vue的实例代码贴出来,再来探讨一下:script src='/script单个复选框...

关于复选框,我想只要会点html的,大多数会用,但今天在Vue的实例中遇到一个小小的问题引发了我的思考。在此我先把Vue的实例代码贴出来,再来探讨一下:

<script src="javascript/vue.min.js"></script>

单个复选框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="javascript/vue.min.js"></script>
</head>
<body>
    <p id="app">
        <p>单个复选框</p>
        <input type="checkbox" id="checkbox" name="checkbox" v-model="message">
        <label for="checkbox">{{message}}</label>
    </p>
    <script>
        new Vue({
            el:"#app",
            data:{
                message:false
            }
        })
    </script>
</body>
</html>

<script> new Vue({ el:"#app", data:{ message:false } }) </script>

看到这里还得再次回顾一下v-model指令与label中的for属性。

1: v-model:前面我已经讲过了:https://blog.csdn.net/tashanhongye/article/details/76467851,看下图:

Vue由单个复选框引发的联想

2:fZ喎?http://www.weiyer.com/Search.asp?KeyWord=/kf/ware/vc/" target="_blank" class="keylink">vcsr00NSjujwvcD4NCjxwcmUgY2xhc3M9"brush:sql;"> for 属性规定 label 与哪个表单元素绑定。

如上面的代码

    

注意for=”checkbox”绑定的是中的id=”checkbox”而不是:name=”checkbox”

<input type="checkbox" id="checkbox" v-model="message">

下面我们再回过头来看看单个复选框的问题,上面的代码输出的结果如下图:
Vue由单个复选框引发的联想

Vue由单个复选框引发的联想

细心的发现,当我没有勾选单个复选框的时候,选框后面显示的是false;当我勾选单个复选框的时候,选框后面显示的是true;

我们再看看上面的代码,在script中我并没有给message以”true”的初始值啊,为什么我选择复选框的时候后面会显示true呢?

讲到这里其实我也没有更好的解释,但让我想起了vue样式绑定中的一个例子,在这个例子中可以看出它们之间有着相同的逻辑关系。下面我把代码贴出来:




<script src="javascript/vue.min.js"></script>

helloworld

<script> new Vue({ el:"#app", data:{ isActive:true } }) </script>

显示的结果如下:

Vue由单个复选框引发的联想

当我把下列代码做一点小小的改动时,又会得到另外一种结果:

    <script>
        new Vue({
            el:"#app",
            data:{
                isActive:false
            }
        })
    </script>

我只是把isActive的值改成:isActive:false.结果就发生了改变。结果如下:

Vue由单个复选框引发的联想

这一次并没有显示active的样式。

两相比较有着相似之处。

Tags:VU UE E由 由单 
作者:网络 来源:叶显明的专栏