<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>表格中的过渡与动画</title>
<style type="text/css">
#app{
width: 600px;
margin: 10px auto;
}
.tb{
border-collapse: collapse;
width: 100%;
}
.tb th{
background-color: #ff8c00;
width: 100%;
}
.tb td,
.tb th{
padding: 5px;
border: 1px solid black;
text-align: center;
}
.add{
padding: 5px;
border: 1px solid black;
margin-bottom: 10px;
}
.del li{
list-style: none;
padding: 10px;
}
.del{
position: absolute;
top: 35%;
left: 40%;
width: 300px;
border: 1px solid rgba(0,0,0,0.2);
transition: all 0.5s;
background-color: lightgray;
}
</style>
</head>
<body>
<div id="app">
<div class="add">
编号:<input type="text" id="id1" v-color v-focus v-model="idx">
品牌名称:<input type="text" v-model="name">
<button @click="add">添加</button>
</div>
<div>
<table class="tb">
<tr>
<th>编号</th>
<th>品牌名称</th>
<th>创立时间</th>
<th>操作</th>
</tr>
<tr v-if="list.length <= 0">
<td colspan="4">没有数据</td>
</tr>
<tr v-for="(item,key,index) in list" :key="index">
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.date | dateFrm("/")}}</td>
<td><a href="javascript:void(0)" @click="del(item.id)">删除</a></td>
</tr>
</table>
</div>
<transition
@before-enter="beforeEnter"
@enter="enter"
@after-enter="afterEnter"
@before-leave="beforeLeave"
@leave="leave"
@after-leave="afterLeave">
<div class="del" v-show="isshow">
<ul>
<li>你确定要删除数据吗?</li>
<li>
<button @click="delById">确定</button>
<button @click="showClose">关闭</button>
</li>
</ul>
</div>
</transition>
</div>
<script src="../js/vue.js"></script>
<script>
Vue.filter("dateFrm",function (time, spliceStr) {
let date = new Date();
let year = date.getFullYear();
let month = date.getMonth() + 1;
let day = date.getDate();
return year + spliceStr + month + spliceStr + day;
});
Vue.directive("focus",{
inserted:function (el) {
el.focus();
}
});
Vue.directive("color",{
inserted:function (el) {
el.style.color = "red";
}
});
let vm = new Vue({
el:'#app',
data:{
delId:"",
isshow:false,
idx:0,
name:'',
list:[
{
id:1,
name:'学习课堂',
date:Date(),
},
{
id:2,
name:'其他课堂',
date:Date(),
},
]
},
methods:{
add:function () {
this.list.push({"id":this.idx,"name":this.name,"date":Date()});
},
del:function (id) {
this.isshow = true;
this.delId = id;
},
beforeEnter:function (el) {
el.style.offsetTop = "80%";
},
enter:function (el, done) {
el.offsetHeight;
el.style.offsetTop = "35%";
},
afterEnter:function (el) {
},
beforeLeave:function (el) {
el.style.offsetTop = "35%";
},
leave:function (el,done) {
el.offsetHeight;
el.style.offsetTop = "80%";
setTimeout(function () {
done();
},500);
},
afterLeave:function (el) {
this.isshow = false;
},
delById:function () {
_this = this;
let index = this.list.findIndex(function (item1) {
return item1.id === _this.delId;
});
this.list.splice(index,1);
this.isshow = false;
},
showClose:function () {
//
this.isshow = false;
}
}
})
</script>
</body>
</html>
vue-例7-6表格中的过渡动画.html
原创
©著作权归作者所有:来自51CTO博客作者虾米大王的原创作品,请联系作者获取转载授权,否则将追究法律责任

提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
vue-例6-6过渡效果.html
【代码】vue-例6-6过渡效果.html。
javascript vue.js 前端 html 过渡效果 -
vue-例6-6过渡效果3.html
【代码】vue-例6-6过渡效果3.html。
javascript 前端 html ci css -
vue-例6-6过渡效果2.html
【代码】vue-例6-6过渡效果2.html。
javascript 前端 html ci css -
vue-例7-1transtion结合css实现过渡动画.html
【代码】vue-例7-1transtion结合css实现过渡动画.html。
javascript css html ci -
vue-例7-4多元素过渡.html
【代码】vue-例7-4多元素过渡.html。
javascript html 前端 ci 数据 -
vue-例7-5多组件的过渡.html
【代码】vue-例7-5多组件的过渡.html。
css javascript html vue.js -
vue-例7-4多元素过渡4.html
【代码】vue-例7-4多元素过渡4.html。
javascript 前端 vue.js html ci -
vue-例7-4多元素过渡2.html
【代码】vue-例7-4多元素过渡2.html。
javascript 前端 vue.js html ci -
vue-例7-4多元素过渡3.html
【代码】vue-例7-4多元素过渡3.html。
javascript 前端 vue.js html ci -
vue-其他列表过渡.html
【代码】vue-其他列表过渡.html。
vue.js javascript 前端 html ci -
vue-例7-2animate.css+transtion实现动画.html
【代码】vue-例7-2animate.css+transtion实现动画.html。
javascript 前端 vue.js html css -
vue-例7-2钩子函数实现动画.html
【代码】vue-例7-2钩子函数实现动画.html。
javascript vue.js 前端 html Vue -
vue-例2-6计算属性.html
【代码】vue-例2-6计算属性.html。
javascript vue.js 前端 html 双向绑定 -
vue-例7-3使用钩子函数实现动画.html
【代码】vue-例7-3使用钩子函数实现动画.html。
javascript 前端 html css vue.js -
vue-其他过渡类名实现.html
【代码】vue-其他过渡类名实现.html。
vue.js javascript 前端 html ci -
vue-例5-6演示嵌套组件.html
【代码】vue-例5-6演示嵌套组件.html。
vue.js javascript 前端 Vue html -
vue-例3-13v-model6.html
【代码】vue-例3-13v-model6.html。
javascript 前端 vue.js html Vue