placeholder for input type date html5

半城伤御伤魂 提交于 2019-11-28 08:22:40

问题


placeholder does not work for input type date directly.

<input required="" type="text" class="form-control" placeholder="Date"/>

instead, it shows mm/dd/yyy

how to show Date?


回答1:


use onfocus="(this.type='date')", example:

<input required="" type="text" class="form-control" placeholder="Date" onfocus="(this.type='date')"/>



回答2:


use onfocus and onblur... Here it's an example:

<input type="text" placeholder="Birth Date" onfocus="(this.type='date')" onblur="if(this.value==''){this.type='text'}">



回答3:


Here, I have tried data attribute in input element. and applied required placeholder using CSS

<input type="date" name="dob" data-placeholder="Date of birth" required aria-required="true" />

    input[type="date"]::before { 
    	content: attr(data-placeholder);
    	width: 100%;
    }
    
    /* hide our custom/fake placeholder text when in focus to show the default
     * 'mm/dd/yyyy' value and when valid to show the users' date of birth value.
     */
    input[type="date"]:focus::before,
    input[type="date"]:valid::before { display: none }
<input type="date" name="dob" data-placeholder="Date of birth" required aria-required="true" />

Hope this helps




回答4:


<input type="text" placeholder="*To Date" onfocus="(this.type='date')" onblur="(this.type='text')" >

This code works for me. Simply you can use this




回答5:


For angular 2,You can use this directive

import {Directive, ElementRef, HostListener} from '@angular/core';

@Directive({
  selector: '[appDateClick]'
})
export class DateClickDirective {
  @HostListener('focus') onMouseFocus() {
    this.el.nativeElement.type = 'date';
    setTimeout(()=>{this.el.nativeElement.click()},2);
  }

  @HostListener('blur') onMouseBlur() {
    if(this.el.nativeElement.value == ""){
      this.el.nativeElement.type = 'text';
    }
  }


  constructor(private el:ElementRef) { }

}

and use it like below.

 <input appDateClick name="targetDate" placeholder="buton name" type="text">


来源:https://stackoverflow.com/questions/30961704/placeholder-for-input-type-date-html5

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!