占位符不能直接用于输入类型日期。
<input required="" type="text" class="form-control" placeholder="Date"/>
相反,它显示 mm / dd / yyy
如何显示日期?
答案 0 :(得分:23)
使用onfocus="(this.type='date')"
,例如:
<input required="" type="text" class="form-control" placeholder="Date" onfocus="(this.type='date')"/>
答案 1 :(得分:8)
使用onfocus和onblur ......这是一个例子:
<input type="text" placeholder="Birth Date" onfocus="(this.type='date')" onblur="if(this.value==''){this.type='text'}">
答案 2 :(得分:2)
<input type="text" placeholder="*To Date" onfocus="(this.type='date')" onblur="(this.type='text')" >
此代码对我有用。只需您可以使用此
答案 3 :(得分:1)
对于角度2,您可以使用此指令
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) { }
}
并像下面一样使用它。
<input appDateClick name="targetDate" placeholder="buton name" type="text">
答案 4 :(得分:1)
在这里,我在data
元素中尝试了input
属性。并使用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 }
&#13;
<input type="date" name="dob" data-placeholder="Date of birth" required aria-required="true" />
&#13;
希望这有帮助