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

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">
下面我们再回过头来看看单个复选框的问题,上面的代码输出的结果如下图:


细心的发现,当我没有勾选单个复选框的时候,选框后面显示的是false;当我勾选单个复选框的时候,选框后面显示的是true;
我们再看看上面的代码,在script中我并没有给message以”true”的初始值啊,为什么我选择复选框的时候后面会显示true呢?
讲到这里其实我也没有更好的解释,但让我想起了vue样式绑定中的一个例子,在这个例子中可以看出它们之间有着相同的逻辑关系。下面我把代码贴出来:
helloworld
<script> new Vue({ el:"#app", data:{ isActive:true } }) </script>显示的结果如下:

当我把下列代码做一点小小的改动时,又会得到另外一种结果:
<script>
new Vue({
el:"#app",
data:{
isActive:false
}
})
</script>
我只是把isActive的值改成:isActive:false.结果就发生了改变。结果如下:

这一次并没有显示active的样式。
两相比较有着相似之处。


