©
Dieses Dokument verwendetPHP-Handbuch für chinesische WebsitesFreigeben
日期输入的验证和转换。目前的浏览器还不支持HTML5的日期输入控件,所以将使用文本输入。 在这种情况下,输入的文本必须符合ISO-8601的日期格式(yyyy-MM-dd)的校验规范,例如:2009-01-06
. 模型必须永远是一个Date对象。
Type="date"ng-model=""[name=""] [min=""] [max=""] [required=""] [ng-required=""] [ng-change=""]>
参数 | 类型 | 详述 |
---|---|---|
ngModel | string | 声明用于数据绑定的Angular表达式。 |
name
(可选)
|
string | 发布到表单下的控件的属性名称。 |
min
(可选)
|
string | 当输入的值小于 |
max
(可选)
|
string | 当输入的值大于 |
required
(可选)
|
string | 如果未输入值就设置 |
ngRequired
(可选)
|
string | 当ngRequired表达式等于true时,添加 |
ngChange
(可选)
|
string | Angular表达式,当输入元素通过用户交互方式发生输入变化时会执行这个表达式。 |
angular.module('dateInputExample',[]).controller('DateController',['$scope',Function($scope){$scope.value=newDate(2013,9,22);}]);
protractor.js
varvalue=element(by.binding('value | date: "yyyy-MM-dd"'));varvalid=element(by.binding('myForm.input.$valid'));varinput=element(by.model('value'));// currently protractor/webdriver does not support// sending keys to all known HTML5 input controls// for various browsers (see https: //github.com/angular/protractor/issues/562).FunctionsetInput(val){// set the value of the element and force validation.varscr="var ipt = document.getElementById('exampleInput'); "+"ipt.value = '"+val+"';"+"angular.element(ipt).scope().$apply(function(s) { s.myForm[ipt.name].$setViewValue('"+val+"'); });";browser.executeScript(scr);}it('should initialize to model',Function(){expect(value.getText()).toContain('2013-10-22');expect(valid.getText()).toContain('myForm.input.$valid = true');});it('should be invalid if empty',Function(){setInput('');expect(value.getText()).toEqual('value =');expect(valid.getText()).toContain('myForm.input.$valid = false');});it('should be invalid if over max',Function(){setInput('2015-01-01');expect(value.getText()).toContain('');expect(valid.getText()).toContain('myForm.input.$valid = false');});