<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>Document</title>
<!--1.导入Vue的包-->
<script src=" https://cdn.jsdelivr.net/npm/vue"></script>
<!-- <link rel="stylesheet" href="./lib/bootstrap.css"> -->
<link rel="stylesheet" href=" https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css">
<!-- 需要用到Jquery吗???不推荐在vue中使用Jquery --> </head> <body>
<div id="app"> <div class="panel panel-primary">
<div class="panel-heading">
<h3 class="panel-title">添加品牌</h3>
</div>
<div class="panel-body form-inline">
<label>
Id:
<input type="text" class="form-control" v-model="id">
</label> <label>
Name:
<input type="text" class="form-control" v-model="name" @keyup.enter="add">
</label>
<!-- 在vue中,使用事件绑定机制,为元素指定处理函数的时候,如果加了小括号,就可以给函数传参了 -->
<input type="button" value="添加" class="btn btn-primary" @click="add()"> <label>
搜索名称关键字:
<!-- 注意:Vue中所有的指令,在调用的时候,都以 v- 开头 -->
<input type="text" class="form-control" v-model="keywords" id="search" v-focus v-color="'blue'">
</label> </div>
</div> <table class="table table-bordered table-hover table-striped">
<thead>
<tr>
<th>Id</th>
<th>Name</th>
<th>Ctime</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<!-- 之前,v-for中的数据,都是直接从data上的list中直接渲染过来的 -->
<!-- 现在,我们自定义了一个方法,同时,把所有的关键字,通过传参的形式,传递给了search方法 -->
<!-- 在search方法内部,通过执行for循环,把所有符合搜索关键字的数据,保存到一个新数组中,返回 -->
<tr v-for="item in search(keywords)" :key="item.id">
<td>{{item.id}}</td>
<td v-text="item.name"></td>
<td>{{ item.ctime | dateFormat()}}</td>
<td>
<a href="" @click.prevent="del(item.id)">删除</a>
</td>
</tr>
</tbody>
</table> </div> <div id="app2">
<h3>{{dt|dateFormat}}</h3>
</div> <script>
//全局的过滤器,进行时间的格式化
//所谓的全局过滤器,就是所有的VM实例都共享
Vue.filter('dateFormat',function(dateStr,pattern=""){
//根据给定的时间字符串,得到特定的时间
var dt = new Date(dateStr) //yyyy-mm-dd
var y=dt.getFullYear()
var m=dt.getMonth()+1
var d=dt.getDate() // return y+'-'+m+'-'+d
//模板字符串 ``
// return `${y}-${m}-${d}` if(pattern.toLowerCase() ==='yyyy-mm-dd'){
return `${y}-${m}-${d}`
}else{
var hh=dt.getHours()
var mm=dt.getMinutes()
var ss=dt.getSeconds() return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
} }) //自定义全局按键修饰符
Vue.config.keyCodes.f2=113 //使用 Vue.directive() 定义全局的指令
//其中,参数1: 指令名称,注意,在定义的时候,指令的名称前面,不需要加 v- 前缀,
//但是:在调用的时候,必须 在指令名称前加上 v- 前缀来进行调用
//参数2:是一个对象,这个对象身上,有一些指令相关的函数,这些函数可以在特定的阶段,执行相关的操作
Vue.directive('focus',{
bind:function(el){//每当指令绑定到元素 上的时候,会立即执行这个bind函数,只执行一次
//注意:在每个函数中,第一参数,永远是el,表示 被绑定了指令的哪个元素,这个el参数,是一个元素原生的JS对象
//在元素刚绑定了指令的时候,还没有插入到DOM中去,这时候,调用focus方法没有作用
//因为,一个元素,只有插入插入DOM之后,才能获取焦点
el.focus()
},
inserted:function(el){//inserted 表示元素 插入到DOM中的时候,会执行 inserted 函数
el.focus()
//和JS行为有关的操作,最后在inserted 中去执行,防止JS行为不生效
},
updated:function(){//当VNode更新的时候,会执行updated,可能会触发多次 }
}) //自定义一个设置字体颜色的指令
Vue.directive('color',{
//样式,只要通过指令绑定给了元素,不管这个元素有没有被插入到页面中去,这个元素肯定有了一个内联的样式
//将来元素肯定会显示到页面中,这时候,浏览器的渲染引擎必然会解析样式,应用给这个元素
bind:function(el,binding){
// el.style.color='red'
//和样式相关的操作,一般都可以在bind执行 el.style.color=binding.value
}
}) //创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el:'#app',
data:{
id:'',
name:'',
keywords:'',//搜索的关键字
list:[
{id:1,name:'奔驰',ctime:new Date()},
{id:2,name:'宝马',ctime:new Date()}
]
},
methods:{
add(){//添加的方法
// console.log('ok')
//分析:
//1.获取到id 和name ,直接从data上面获取
//2.组织出一个对象
//3.把这个对下,调用数组的相关方法,添加到当前data上的list中
//4.注意:在Vue中,已经实现了数据的双向绑定,每当我们修改了data中的数据,Vue会默认监听到数据的改动,自动把最新的数据,应用到页面上;
//5.当我们意识到上面的第四部的时候,就证明大家已经入门Vue了,我们更多的是在进行VM中Model数据操作,同时,在操作Model数据的时候,指定的业务逻辑操作; var car={id:this.id,name:this.name,ctime:new Date()}
this.list.push(car)
this.id=this.name=''
},
del(id){//根据Id删除数据
//分析:
//1.如何根据Id,找到要删除这一项的索引
//2.如果找到索引了,直接调用数组的splice方法 /* this.list.some((item,i)=>{
if(item.id==id){
this.list.splice(i,1)
//在数组的some方法中,如果return true,就会立即终止这个数组的后续循环
return true;
}
})*/ var index = this.list.findIndex(item=>{
if(item.id==id){
return true;
}
})
// console.log(index)
this.list.splice(index,1)
}, search(keywords){//根据关键字,进行数据的搜索
/* var newList=[]
this.list.forEach(item=>{
if(item.name.indexOf(keywords)!=-1){
newList.push(item)
}
})
return newList*/
//注意:forEach some filter findIndex 这些都属于数组的新方法,
//都会对数组中的每一项,进行遍历,执行相关操作;
return this.list.filter(item=>{
// if(item.name.indexOf(keywords)!=-1)
//注意:在ES6中,为字符串提供了一个新方法,叫做String.prototype.includes('要包含的字符串')
//如果包含,则返回true,否则返回false
//contains
if(item.name.includes(keywords)){
return item
}
})
}
}
}); //如何自定义一个私有的过滤器()
var vm2=new Vue({
el:'#app2',
data:{
dt:new Date()
},
methods:{},
filters:{//定义私有过滤器 过滤器有两个条件【过滤器名称和处理函数】
//过滤器调用的时候,采用的是就近原则,如果有过滤器和全局过滤器名称一致了,这时候 有线调用私有过滤器
dateFormat:function(dateStr,pattern=''){
//根据给定的时间字符串,得到特定的时间
var dt = new Date(dateStr) //yyyy-mm-dd
var y=dt.getFullYear()
var m=(dt.getMonth()+1).toString().padStart(2,'0')
var d=(dt.getDate()).toString().padStart(2,'0') if(pattern.toLowerCase() ==='yyyy-mm-dd'){
return `${y}-${m}-${d}`
}else{
var hh=dt.getHours().toString().padStart(2,'0')
var mm=dt.getMinutes().toString().padStart(2,'0')
var ss=dt.getSeconds().toString().padStart(2,'0') return `${y}-${m}-${d} ${hh}:${mm}:${ss} ~~~~~~~`
}
}
} }) // document.getElementById('search').focus() </script>
</body>
</html>

最新文章

  1. plain framework 商业版 开发总结2 项目管理器
  2. Form文件夹开发步骤
  3. C# 类型基础
  4. CSS培训机构
  5. 使用 EasyMock 更轻松地进行测试
  6. HW7.2
  7. 解决libpython2.6.so.1.0: cannot open shared object file
  8. Boost.Build 简明教程
  9. magento xml配置详解
  10. Java连接各类数据库
  11. 关于webroot与web-inf
  12. Node-debug方法
  13. [JLOI 2012]树
  14. 51nod1305
  15. js模拟下拉框
  16. 修改Linux SSH连接端口和禁用IP,安装DDoS deflate
  17. python3 利用pip安装ipython notebook
  18. spring: 在Spring应用中使用JDBC(使用profiles选择数据源/使用基于JDBC驱动的数据源)
  19. 洛谷 P1181 数列分段Section I【贪心/最少分成多少合法的连续若干段】
  20. 一次程序bug的排查

热门文章

  1. HNU_团队项目_数据库设计感想_个人感想
  2. Lua for Mac环境搭建
  3. 闲记Windows 取证艺术
  4. 非常好的一个JS代码(FixedMenu.htm)
  5. JS 根据字节 截取字符串函数
  6. 【C++ 学习笔记】 MFC CEdit
  7. Oracle中ORA-01113,ORA-01110的简单解决
  8. 【0.3】mysql复制的日常管理维护,mysql复制常见问题处理
  9. __metaclass__方法
  10. liunx 安装rsync