md-selectを使用して、選択した値をクリアできるようにしたいと考えています。例えば。彼らは値を選択するが、彼らは選択をクリアしたいと決める。md-selectの値をクリアする方法
md-selectの動作は、オプションの最初のエントリを選択することです。私はそれが選択されていない状態に戻るようにしたいと思います。
私はおそらくこのためにカスタムディレクティブが必要だと思います。そのため、DELETEキーのキーダウンを聞く簡単なディレクティブを実装しました。
HTML:
<div ng-controller="AppCtrl as ctrl" class="md-padding selectdemoBasicUsage" ng-cloak="" ng-app="MyApp">
<div>
<h1 class="md-title">Select a state</h1>
<span>I want the DELETE key to be able to clear the selected state.</span>
<div layout="row">
<md-input-container>
<label>State</label>
<md-select ng-model="ctrl.userState" select-clear>
<md-option ng-repeat="state in ctrl.states" value="{{state.abbrev}}">
{{state.abbrev}}
</md-option>
</md-select>
</md-input-container>
</div>
</div>
</div>
JS:
(function() {
'use strict';
angular
.module('MyApp',['ngMaterial', 'ngMessages'])
.controller('AppCtrl', function() {
this.userState = '';
this.states = ('AL AK AZ AR CA CO CT DE FL GA HI ID IL IN IA KS KY LA ME MD MA MI MN MS ' +
'MO MT NE NV NH NJ NM NY NC ND OH OK OR PA RI SC SD TN TX UT VT VA WA WV WI ' +
'WY').split(' ').map(function (state) { return { abbrev: state }; });
})
.directive('selectClear', function() {
return {
restrict: 'A',
require: 'ngModel',
link : function(scope, iElement, iAttrs, ngModelCtrl) {
iElement.bind('keydown', function(event) {
if (event.keyCode === 46) {
ngModelCtrl.$setViewValue('', event);
}
})
}
}
});
})();
ここに私のコードのペンだ:
http://codepen.io/craigsh/pen/GorpVV
しかし、それは動作しません - DELET Eキーを押すと、最初のオプション値が選択されます。
http://codepen.io/petert/pen/vGJLjB –