新上線了一個vue的移動端項目,其中用到了時間控件,可是input[type='date']沒有placeholder屬性,網上查到的方法是<input type='text' onfocus='this.type="date"'>,這種方法在ios上是沒問題的,可是在安卓上則須要點擊兩次才能夠調起系統的時間控件。所以決定本身寫個組件,解決安卓上的兼容性問題。代碼以下:vue
<template> <div class="date_container"> <input id="show-date" type="text" :value="date" disabled :placeholder="placeholder"/> <input id="date" type="date" @change="changeDate"/> </div> </template> <script> export default{ data(){ let today = new Date() return { date: '' } }, props:{ dateType:{ type: String, default: '' }, defaultDate:{ type: String, default: '' }, placeholder:{ type: String, default: '點擊選擇日期' }, to:{ type: Object } }, created(){ this.date = this.defaultDate if(!this.placeholder) { this.placeholder = '點擊選擇日期' } }, mounted(){ }, methods: { input:function(e){ // alert(e.target.value); // if ('' === e.target.value) { // this.date = '' // alert(this.date); // } }, changeDate: function (event) { // alert('this.date=='+this.date); // alert(event.target.value); this.date = event.target.value.replace(/-/g,'.') console.log(this.date); this.$emit('setComponentDate', this.date.replace(/-/g,'.') ,this.dateType,this.to) } } } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped> .date_container{ width:100%; height:100%; position:relative; overflow:hidden; } .date_container input{ display:inline-block; width:100%; height:100%; background: white; position:absolute; top:0; text-align: center; line-height:normal; } input[type='text']{ /*opacity:0.0;*/ color:#4c576f ; } input[type='datetime-local']{ background: paleturquoise; opacity:0.0; } input[type='date']{ width:3rem; height:100%; background: paleturquoise; opacity:0.0; } ::-webkit-input-placeholder { color:#b3bcce; font-size:.14rem; } input[disabled]{opacity:1} .addContainer input[type='text']{ text-align: right; } </style>
使用代碼爲ios
<Date @setComponentDate="setComponentDate" dateType="start" :defaultDate="p.from_on" placeholder="請輸入" :to="{which:'others',index:$index,dateType:'from_on'}"/>