抖音资讯

douyinzx

vue格式化日期格式(vue日期时间选择组件)

iseeyu2年前 (2024-05-05)抖音资讯116

在前面我们介绍了vue的综合小案例把前面介绍的一些常用指令我们综合运用了一下,但是还有个小问题,就是显示的'创建时间 cTime'的格式没有处理,虽然我们可以在后台服务处理好后再传递给前端,但是在前端应该也需要能够自主地处理,而我们刚刚介绍了Vue中的过滤器,刚好可以通过Vue的过滤器来解决这个问题,我们来具体看下~

 

在这里插入图片描述

过滤器应用

案例代码

  以下是没有格式化处理之前的代码,效果图就是上面的截图

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="./lib/vue-2.4.0.js"></script>
    <link rel="stylesheet" href="./lib/bootstrap-3.3.7.css">
</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">
                    </label>


                    <input type="button" value="添加" class="btn btn-primary" @click='add'>

                    <label>
                        搜索名称关键字:
                        <input type="text" class="form-control" v-model="keywords">
                    </label>    
              </div>
        </div>



        <table class="table table-bordered table-hover table-striped">
            <thead>
                <tr>
                    <th>id</th>
                    <th>name</th>
                    <th>cTime</th>
                    <th>操作</th>
                </tr>
            </thead>
            <tbody>
                <tr v-for="item in search(keywords)" :key="item.id">
                    <td>{{item.id}}</td>
                    <td>{{item.name}}</td>
                    <td>{{item.ctime  }}</td>
                    <td><a href="" @click.prevent="del(item.id)">删除</a></td>
                </tr>
            </tbody>
        </table>



    </div>
    <script> 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(){ // 添加记录到list中 this.list.push({id:this.id,name:this.name,ctime:new Date()}) // 将输入框置空 this.id=this.name='' }, del(id){ // some方法循环数组,返回true可以终止循环 // this.list.some((item,i) =>{ // if(item.id == id){ // 移除记录 1 移除一条记录 // this.list.splice(i,1); // 返回true 终止循环 // return true; // } //})  // 通过findIndex方法获取要删除记录的index var index = this.list.findIndex(item => { if(item.id == id){ return true } }) // 通过splice方法来移除记录 this.list.splice(index,1); }, search(keywords){ // 保存新的数组 // var newList = [] // this.list.forEach(item => { // 判断循环的记录是否包含的查询的关键字 // if(item.name.indexOf(keywords) != -1){ // 将循环的记录添加到新的数组中 // newList.push(item) // } // }) // 返回数组信息 // return newList // filter 过滤 返回满足条件的数组 return this.list.filter(item => { // includes 是否包含 if(item.name.includes(keywords)){ return item } }) } } }) </script>
</body>
</html>

局部过滤器

  此处案例中我们通过局部过滤器来实现,当然你也可以通过全局过滤器来实现

 

在这里插入图片描述

显示效果

 

在这里插入图片描述

我们发现显示的月份7最好是显示为07,这时我们可以使用一个ES6中新增的方法叫 padStart方法

方法

说明

String.prototype.padStart(maxLength, fillString='')

字符串长度为maxLength,不够的在开头用fillString填充,
例如 :"123".padStart(6,"a")="aaa123"

String.prototype.padEnd(maxLength, fillString='')

这个和上面类似,是在结尾处填充,
例如"123".padEnd(6,"a")="123aaa"

 

在这里插入图片描述

 

在这里插入图片描述

此处仅仅介绍padStart的用法,实际开发场景中应该将天数也要padStart处理

显示时分秒

  有时我们显示Date类型数据的时候,我们希望能够把时分秒也给显示出来,这时为了灵活点我们可以通过参数来动态设置。

 

在这里插入图片描述

调用过滤器的时候传递参数

 

在这里插入图片描述

效果

 

在这里插入图片描述

最后完成代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="./lib/vue-2.4.0.js"></script>
    <link rel="stylesheet" href="./lib/bootstrap-3.3.7.css">
</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">
                    </label>


                    <input type="button" value="添加" class="btn btn-primary" @click='add'>

                    <label>
                        搜索名称关键字:
                        <input type="text" class="form-control" v-model="keywords">
                    </label>    
              </div>
        </div>



        <table class="table table-bordered table-hover table-striped">
            <thead>
                <tr>
                    <th>id</th>
                    <th>name</th>
                    <th>cTime</th>
                    <th>操作</th>
                </tr>
            </thead>
            <tbody>
                <tr v-for="item in search(keywords)" :key="item.id">
                    <td>{{item.id}}</td>
                    <td>{{item.name}}</td>
                    <td>{{item.ctime | msgDateFormat('yyyy-mm-dd hh-mi-ss') }}</td>
                    <td><a href="" @click.prevent="del(item.id)">删除</a></td>
                </tr>
            </tbody>
        </table>



    </div>
    <script> 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(){ // 添加记录到list中 this.list.push({id:this.id,name:this.name,ctime:new Date()}) // 将输入框置空 this.id=this.name='' }, del(id){ // some方法循环数组,返回true可以终止循环 // this.list.some((item,i) =>{ // if(item.id == id){ // 移除记录 1 移除一条记录 // this.list.splice(i,1); // 返回true 终止循环 // return true; // } //})  // 通过findIndex方法获取要删除记录的index var index = this.list.findIndex(item => { if(item.id == id){ return true } }) // 通过splice方法来移除记录 this.list.splice(index,1); }, search(keywords){ // 保存新的数组 // var newList = [] // this.list.forEach(item => { // 判断循环的记录是否包含的查询的关键字 // if(item.name.indexOf(keywords) != -1){ // 将循环的记录添加到新的数组中 // newList.push(item) // } // }) // 返回数组信息 // return newList // filter 过滤 返回满足条件的数组 return this.list.filter(item => { // includes 是否包含 if(item.name.includes(keywords)){ return item } }) } }, filters:{ // 通过局部过滤器来实现 msgDateFormat:function(msg,pattern=''){ // 将字符串转换为Date类型 var mt = new Date(msg) // 获取年份 var y = mt.getFullYear() // 获取月份 从0开始  var m = (mt.getMonth()+1).toString().padStart(2,"0") // 获取天数 var d = mt.getDate(); if(pattern === 'yyyy-mm-dd'){ return y+"-"+m+"-"+d } // 获取小时 var h = mt.getHours().toString().padStart(2,"0") // 获取分钟 var mi = mt.getMinutes().toString().padStart(2,"0") // 获取秒 var s = mt.getSeconds().toString().padStart(2,"0") // 拼接为我们需要的各式 return y+"-"+m+"-"+d+" "+h+":"+mi+":"+s } } }) </script>
</body>
</html>

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://0291.com.cn/post/44641.html

相关文章

谷歌信息流广告计费模式是怎样的?

谷歌信息流广告计费模式是怎样的?

直播观看会到达一万以上,同时这个商家在直播间直播过程中会通过视频进行引流。开播前会发布视频预热。开播中会发布视频引流当天会发布十几条视频。第四点的话,商家会在直播间做上新的活动,上新的频率高,两天一次的上新,直播间的新款谷歌信息流竞价高信誉非常高。同时主播语速非常快,跟粉丝能够保持高频率的互动,每个...

抖音插曲音乐怎么剪辑(抖音剪辑视频教学)

抖音插曲音乐怎么剪辑(抖音剪辑视频教学)

抖音音乐剪辑怎么做? 抖音上情感音乐类短视频涨粉,这里有音乐号大咖的搞法。 制作音乐短视频只需要简单的素材,例如城市夜景和人流拍摄的视频,我们可以通过自动混剪工具,添加视频素材,进行简单的镜头过渡等设置,即可自动生成原创音乐短视频。  ...

360推广平台账户搭建工作可别小瞧了这项工作

360推广平台账户搭建工作可别小瞧了这项工作

360推广平台账户搭建工作可别小瞧了这项工作: 360推广效果怎么样做SEM的童鞋都知道,我们从事的是一项很细致的工作,优化之路持续而长久。那么,如何在这项艰苦、细致、漫长的工作中提高我们的工作效率,提升优化效果呢?今天小编就给你支招! 第一步要做好的就是账户搭建工作。可别小瞧了这项工作,这是...

ps怎么做立体字效果(制作立体效果的妙招)

ps怎么做立体字效果(制作立体效果的妙招)

每到节日的时候,网上的商家都会做优惠活动,各种优惠海报应有尽有。我们经常能看到这些海报都有一些比较有趣的立体文字,很多都是用AI或者CDR软件去制作的,那网友就有疑问了,用PS可不可以制作呢?答案是肯定的。 接下来我们就一起来学习如何制作立体文字吧! 1.首先打开我们的PS,新建一个新...

抖音盒子赚钱吗?抖音如何变现?(抖音小程序变现真的能赚钱吗)

抖音盒子赚钱吗?抖音如何变现?(抖音小程序变现真的能赚钱吗)

现在很多人都在玩抖音营销,但是却不知道怎么利用抖音进行变现,很多人都没有一个很好的变现思路,玩的好的朋友顶多也就一两个变现方法。那么抖音盒子赚钱吗?下面进行介绍。 抖音如何变现? 抖音盒子赚钱吗? 是可以赚钱变现的。 抖音盒子现在下载的大部分还是达人、商家、品牌方,消费者还是比...

百度聚屏广告的开户电话您知道是多少吗?

百度聚屏广告的开户电话您知道是多少吗?

聚合线下多类屏幕,利用百度平台优势、数据能力、AI能力,赋能屏幕;触达消费者多场景生活时刻 ,实现线下广告的整合、精准程序化投放。 聚屏GD新平台已上线 ,GD新平台能够解决销售自主售卖下单提升售卖效率。目前支持资源:影院、门禁等,其他GD资源依然按照之前培训流程,邮件询量询价,锁量,传物料审...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片