抖音资讯

douyinzx

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

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

在前面我们介绍了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://www.0291.com.cn/post/44641.html

相关文章

360wifi怎么安装在电脑上(台式电脑连接360wifi的教学)

360wifi怎么安装在电脑上(台式电脑连接360wifi的教学)

还记得当时风靡办公室的360随身WiFi么?不少办公室的白领和学生朋友们,使用这个小小的设备,解决了自己的手机、平板电脑等无法通过WiFi上网的难题。现在,360随身WiFi推出了第三代的产品,硬件性能全新升级,外观华丽蜕变,更加方便用户使用。目前,360随身WiFi第三代正在预约中,将于1月2...

抖音有播放量就有收益吗(抖音发布视频播放量)

抖音有播放量就有收益吗(抖音发布视频播放量)

"抖音" 是一款短视频制作和分享的移动应用程序。它是由字节跳动公司开发的,该公司总部位于中国北京。 抖音视频播放量 抖音允许用户制作短时间的视频,并通过社交媒体平台分享。该应用程序非常受欢迎,特别是在年轻人中,因为它提供了一种轻松、有趣的方式来创建和分享内容。...

抖音直播电视剧怎么弄(抖音直播影视剧教程)

抖音直播电视剧怎么弄(抖音直播影视剧教程)

很多人在抖音上看到其他主播直播电影和电视剧,他们的账号没有被封禁,而且有很多观众和丰厚的收益。因此,许多人也想知道如何用自己的账号来直播电影和电视剧。然而,当我们开始直播时,很快就发现直播间会被封禁,即使播放的是西瓜视频中的电影电视剧,也会被封禁。当我们在网上搜索如何在抖音直播电影电视剧的教程时...

物联网的特点有哪些(物联网的基本特征)

物联网的特点有哪些(物联网的基本特征)

物联网的特点 物联网具有三大特点:全面感知、可靠传输、智能处理。 1. 全面感知:物联网连接的是物,需要能够感知物,赋予物智能,从而实现对物 的感知。其感知方式和感知信息如下图所示: 2. 可靠传输:物联网通过前端感知层收集各类信息,还需要通过可靠的传输网络 将感知的各种...

抖音的拍摄以及基础的运营技巧

抖音的拍摄以及基础的运营技巧

需要用到的工具 1.拍摄需要的工具 (1)拍摄设备 对于绝大部分新手来说,拍视频用手机就足够,前期完全不需要用到相机。但是拍摄的手机建议在800w像素及以上,手机分辨率设置为1080P及以上(如果支持4K的话,调成4K),30帧以上。 (2)稳定器 用手拍摄的话屏幕会很抖,...

快手广告平台:用户/账户/组织/主体/公司定义+ 角色权限范围【1】

快手广告平台:用户/账户/组织/主体/公司定义+ 角色权限范围【1】

用户(user_id): 快手广告平台的使用者, 通过用户来标识用户身份、权限、数据范围,用户注册/登陆平台使用的邮箱(手机号)密码、用户名称等信息来指代用户。用户可被组织邀请成为成员 组织(cc_id) : 一个所有者的商业...

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

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