總結一下作移動端項目遇到的坑

 

 

新上線了一個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'}"/>
相關文章
相關標籤/搜索