1、在專案中用到了element ui裡面的日期選擇器,發現有格式問題,如下程式碼:
<template v-if="scope.row.edit">
<el-date-picker
class="stra-date-picker"
size="small"
v-model="scope.row.publish_time"
type="date"
placeholder="請選擇日期">
</el-date-picker>
</template>
<span v-else class="db ell" :title="scope.row.publish_time">{{ scope.row.publish_time }}</span>
複製程式碼
選擇日期的時候格式並沒有問題,如下:
data:image/s3,"s3://crabby-images/feb22/feb22293529f51406305a4d413c27db16aa8e21c" alt="使用element ui 日期選擇器獲取值後的格式問題"
data:image/s3,"s3://crabby-images/81ebf/81ebfec671d4b8f8ae304487f93dc142fab7805b" alt="使用element ui 日期選擇器獲取值後的格式問題"
data:image/s3,"s3://crabby-images/5af70/5af703904670014c3b9f23c27e3c3633d3bb6c48" alt="使用element ui 日期選擇器獲取值後的格式問題"
2、知道問題後檢視官方文件,有這麼一段描述:
data:image/s3,"s3://crabby-images/95628/956287cfb77b96cb7e35967531fab9851f989e0c" alt="使用element ui 日期選擇器獲取值後的格式問題"
3、解決方案1(不適用於我這個專案,但是適用於大部分的專案)
由於在官方文件中,有提到可以使用change
<el-date-picker type="date" v-model="time" @change="formatTime" format="yyyy-MM-dd" placeholder="請選擇日期"></el-date-picker>
複製程式碼
然後在methods中,新增一個方法即可,程式碼如下:
formatTime(val) {
this.time=val;
}
複製程式碼
這個方法是直接將v-model裡面的值改變,但由於我的專案日期裡面v-model的值,是整個動態迴圈繫結的,不能知道當前的time值,所以可用下面的方法2
4、解決方法2(適用於我的專案,個人認為更加方便簡潔)
程式碼如下:
<template v-if="scope.row.edit">
<el-date-picker
class="stra-date-picker"
size="small"
v-model="scope.row.publish_time"
type="date"
value-format="yyyy-MM-dd"
placeholder="請選擇日期">
</el-date-picker>
</template>
<span v-else class="db ell" :title="scope.row.publish_time">{{ scope.row.publish_time }}</span>
複製程式碼
效果如下:
data:image/s3,"s3://crabby-images/3e606/3e60649d804bacb95f4a5f519c2854c06dc4f458" alt="使用element ui 日期選擇器獲取值後的格式問題"
data:image/s3,"s3://crabby-images/514b9/514b9b684fc62c0124d022211c8a85208f17dd8d" alt="使用element ui 日期選擇器獲取值後的格式問題"
data:image/s3,"s3://crabby-images/8d8f0/8d8f0e4956f20914c63b4af5cb6bd06dcca36da4" alt="使用element ui 日期選擇器獲取值後的格式問題"
主要是用了value-format,官方文件解釋如下:
data:image/s3,"s3://crabby-images/e92c7/e92c7e6714de32632c89cacf4baf7773d7dbb10c" alt="使用element ui 日期選擇器獲取值後的格式問題"
戳這裡✔️ 日期格式