<html>
<head>
<meta charset="UTF-8" />
<title>初始条件渲染</title>
<!-- 引入Vue -->
<script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
<div id="root">
<!-- 1.遍历数组 -->
<h2>人员列表</h2>
<input type="text" placeholder="请输入名字" v-model="keyWord">
<u1>
<li v-for="(p,index) in filePersons" :key="index">
{{p.id}}--{{p.name}}--{{p.age}}--{{index}}
</li>
</u1>
</div>
</body>
<script type="text/javascript">
// Vue.config.productionTip = false
// Vue.config.productionTip= false //阻止Vue 在启动时生成生产提示
// 创建Vue实例
new Vue({
el: '#root', //el用于指定当前Vue实例为那个容器服务,值通常为css选择器字符串
// 遍历数组
data: {
keyWord: '',
persons: [
{ id: '001', name: '马冬梅', age: 19, sex: '女' },
{ id: '002', name: '周冬雨', age: 20, sex: '女' },
{ id: '003', name: '周杰伦', age: 21, sex: '女' },
{ id: '004', name: '温兆伦', age: 22, sex: '女' }
],
// filePersons: []
},
// 用计算属性来实现过滤比较简单(比较推荐的过滤方式)
computed:{
filePersons(){
return this.persons.filter((p)=>{
return p.name.indexOf(this.keyWord) !== -1
})
}
}
// watch: {
// keyWord: {
// immediate:true,
// handler(val) {
// console.log('keyWord被修改了', val)
// this.filePersons = this.persons.filter((p) => {
// return p.name.indexOf(val) !== -1
// })
// }
// }
// }
})
</script>
</html>