Vue导包使用:
Vue简单使用:mustache语法(双花括号语法)只适用于元素的内容,对于元素内部属性(用v-bind)修改不适用。
v-once:<h2 v-once> {{message}} </h2>
加了v-once属性后之后message的值发生改变此处的值不变,他处的引用值依旧可变。
v-pre:<h2 v-pre> {{message}} </h2>
加了v-pre属性后其里面的内容不进行解析,原封不动的展现。
v-cloak:
v-html:
v-bind:
1、动态绑定class(对象语法),v-bind中的类名会与前面固定的类名合并,active与line的属性是否生效由isActive和isLine的值决定(布尔类型)。v-bind可用 :类名 代替
<div class="title" v-bind:class="{active:isActive,line:isLine}"></div>
2、动态绑定class(数组语法),类名由active与line属性指向的值决定
<div class="title" :class="[active,line]"></div>
3、计算属性
计算属性的完整内容(可省略)
v-text:会把之前元素里的内容覆盖掉
<div v-text="message"></div>
与js区别:
v-for遍历数组或对象(v-for加自身,即要复制的元素上):
v-for="(m,index) in movise"则可通过index访问下标
methods属性添加监听事件:
简单实现当点击列表时其颜色变化,其他不变:
<style>
.red{
color: red;
}
</style>
</head>
<body>
<div id="app">
<ul>
<!--(value,key,index)分别对应值、属性、下标-->
<li v-for="(m,index) in message" @click="iclick(index)" :class="{red:index==isRed}">{{m}}</li>
</ul>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script>
var app=new Vue({
el:'#app',
data:{
message:['还抵赖','bihdoj','eqwefwd','wqe'],
isRed:0,
},
methods:{
iclick:function(index){
this.isRed=index;
}
}
})
</script>
v-on参数问题:
v-on修饰符: