vue所有基础语法部分
data:image/s3,"s3://crabby-images/7aca1/7aca19ea64dacbf8baebc5b4d82cfe54ba1a3535" alt=""
? ? ? ? ? ??data:image/s3,"s3://crabby-images/8105b/8105b873f738f7fabf1b6c62198e4f5e1b899307" alt=""
????????data:image/s3,"s3://crabby-images/0822d/0822d8bc04b3a772e17408233d191a01b70815d9" alt=""
?????????data:image/s3,"s3://crabby-images/aa98b/aa98be7b04ff865ca6f3fba742760232ffc44ac2" alt=""
?????????data:image/s3,"s3://crabby-images/0c8e2/0c8e26c0194babba7f4ef9944d0c7f7ee279fecb" alt=""
????????????????可以使用 v-cloak 指令设置样式,这些样式会在 Vue 实例编译结束时,从绑定的 HTML ????????元素上被移除。
????????????????当网络较慢,网页还在加载 Vue.js ,而导致 Vue 来不及渲染,这时页面就会显示出 Vue ????????源代码。我们可以使用 v-cloak 指令来解决这一问题。
<div id="app" v-cloak>
<h2>{{message}}</h2>
</div>
<script src="../js/vue.js"></script>
<script>
// 在vue解析之前, div中有一个属性v-cloak
// 在vue解析之后, div中没有一个属性v-cloak
setTimeout(function () {
const app = new Vue({
el: '#app',
data: {
message: '你好啊'
}
})
}, 1000)
</script>
绑定属性
????????data:image/s3,"s3://crabby-images/9f6ce/9f6ce9c743daa74c84f8f461af4ffec8308cdd8a" alt=""
?v-bind语法糖
data:image/s3,"s3://crabby-images/49570/4957083502b26f89aed655c882da4b83a267b36e" alt=""
?v-bind动态绑定class的多种方法
v-bind绑定style(一)data:image/s3,"s3://crabby-images/0f96a/0f96aafc74f7e086f38462fc7f829fa5b7fa9375" alt=""
<style>
.title {
font-size: 50px;
color: red;
}
</style>
</head>
<body>
<div id="app">
<!--<h2 :style="{key(属性名): value(属性值)}">{{message}}</h2>-->
<!--'50px'必须加上单引号, 否则是当做一个变量去解析-->
<!--<h2 :style="{fontSize: '50px'}">{{message}}</h2>-->
<!--finalSize当成一个变量使用-->
<!--<h2 :style="{fontSize: finalSize}">{{message}}</h2>-->
<h2 :style="{fontSize: finalSize + 'px', backgroundColor: finalColor}">{{message}}</h2>
<h2 :style="getStyles()">{{message}}</h2>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊',
finalSize: 100,
finalColor: 'red',
},
methods: {
getStyles: function () {
return {fontSize: this.finalSize + 'px', backgroundColor: this.finalColor}
}
}
})
</script>
</body>
?v-bind绑定style(二)data:image/s3,"s3://crabby-images/6dfbb/6dfbb6e8e4051d92a19f9eceedf03be8112a5cb6" alt=""
?
<div id="app">
<h2 :style="[baseStyle, baseStyle1]">{{message}}</h2>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊',
baseStyle: {backgroundColor: 'red'},
baseStyle1: {fontSize: '100px'},
}
})
</script>
计算属性
data:image/s3,"s3://crabby-images/b3989/b398939e18eaeeb33a0ea19666214101108f0fe1" alt=""
?
<div id="app">
<h2>{{firstName + ' ' + lastName}}</h2>
<h2>{{firstName}} {{lastName}}</h2>
<h2>{{getFullName()}}</h2>
<h2>{{fullName}}</h2>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
firstName: 'Lebron',
lastName: 'James'
},
// computed: 计算属性()
computed: {
fullName: function () {
return this.firstName + ' ' + this.lastName
}
},
methods: {
getFullName() {
return this.firstName + ' ' + this.lastName
}
}
})
</script>
计算属性的setter和getter
data:image/s3,"s3://crabby-images/e88e1/e88e13f7c76a34216948fff33e70bcd27b3d3d82" alt=""
<div id="app">
<h2>{{fullName}}</h2>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
firstName: 'Kobe',
lastName: 'Bryant'
},
computed: {
// fullName: function () {
// return this.firstName + ' ' + this.lastName
// }
// name: 'coderwhy'
// 计算属性一般是没有set方法, 只读属性.
fullName: {
set: function(newValue) {
// console.log('-----', newValue);
const names = newValue.split(' ');
this.firstName = names[0];
this.lastName = names[1];
},
get: function () {
return this.firstName + ' ' + this.lastName
}
},
// fullName: function () {
// return this.firstName + ' ' + this.lastName
// }
}
})
</script>
?事件监听
????????data:image/s3,"s3://crabby-images/46a31/46a31dc1646be70c65a0947f7e3e6a5a44a7446c" alt=""
条件判断
????????
<div id="app">
<h2 v-if="isShow">
<div>abc</div>
<div>abc</div>
<div>abc</div>
<div>abc</div>
<div>abc</div>
{{message}}
</h2>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊',
isShow: true
}
})
</script>
????????
<div id="app">
<h2 v-if="isShow">
<div>abc</div>
<div>abc</div>
<div>abc</div>
<div>abc</div>
<div>abc</div>
{{message}}
</h2>
<h1 v-else>isShow为false时, 显示我</h1>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊',
isShow: true
}
})
</script>
????????data:image/s3,"s3://crabby-images/24985/24985c9e8d2a9991aa8c55af12c1358256842b92" alt=""
?
<div id="app">
<h2 v-if="score>=90">优秀</h2>
<h2 v-else-if="score>=80">良好</h2>
<h2 v-else-if="score>=60">及格</h2>
<h2 v-else>不及格</h2>
<h1>{{result}}</h1>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
score: 99
},
computed: {
result() {
let showMessage = '';
if (this.score >= 90) {
showMessage = '优秀'
} else if (this.score >= 80) {
showMessage = '良好'
}
// ...
return showMessage
}
}
})
</script>
v-show和v-if的区别
data:image/s3,"s3://crabby-images/9295c/9295c13452183b718a1b33aff4804687aaf8db92" alt=""
?
|