我想做一件简单的事情——当有人点击我的 ui-select 时,我希望它自动下拉。不幸的是,当焦点更改为 ui-select 时,ng-focus 似乎没有触发。有解决方法吗?
问问题
4615 次
2 回答
1
如果您正在寻找快速解决方法,请尝试此操作:
app.directive('showOnFocus', function() {
return {
restrict: 'A',
link: function (scope, element) {
var focused = false, opened = false;
var select = element.children('.selectize-input');
var toggleInput = element.find('input')[0];
var onfocus = function(){
if(!focused && !opened) {
toggleInput.click();
opened = focused = true;
} else if(opened) {
opened = false;
}
};
var onhover = function(){
if(!focused && !opened){
toggleInput.click();
opened = focused = true;
};
};
var onblur = function(){
focused = false;
};
element.bind('mouseenter', onhover);
element.bind('click',onblur);
select.bind('blur', onblur);
select.bind('focus', onfocus);
//show on pageload
onhover();
}
};
});
并在您的 ui-select 元素中应用该指令
<ui-select show-on-focus>..</ui-select>
希望这可以帮助。
于 2014-12-31T18:30:34.720 回答
0
showOnFocus 指令对我不起作用。我添加了一个额外的输入(隐藏,但不是不可见)成为焦点,并关闭了 ui-select 的 tabindex。
<custom-directive>
<input class="custom-focuser" tabindex="0" style="left: 10000px"/>
<ui-select tabindex="-1"/>
</custom-directive>
然后在自定义指令的链接函数中,我附加了附加输入的焦点事件。
app.directive('customDirective', function () {
return {
// ...
link: function ($scope, el, attrs, ctrl) {
el.find('.custom-focuser').focus(function (event) {
//your custom logic here
});
}
};
});
于 2015-08-11T20:15:10.120 回答