我有一个辅助函数,用于将输入与jQuery自动完成绑定,并带有一组额外选项,如悬停时显示bootstrap popover,使用辅助标签的能力等等... 我遇到一个问题,当从自动完成列表中选择项目时,我的ngModel没有更新。此自动完成选择将更新文本字段(显示值)和隐藏字段(值)。我想将其更改为指令并在text&中通知ngModel选择项目的值字段。
bindAutocomplete: function (textSelector, valSelector, serviceUrl,
secondaryLabel, minLength, selectCallback,
tooltipPlacement, showOnTopOfField) {
if (!tooltipPlacement) {
tooltipPlacement = "right";
}
var autoCOmpletePosition = { my: "left bottom", at: "left top", collision: "flip" };
if (!showOnTopOfField || showOnTopOfField == false) {
var autoCOmpletePosition = { my: "left top", at: "left bottom", collision: "none" };
}
if (!minLength)
minLength = 2;
var jTextSelector = $(textSelector),
jValSelector = $(valSelector),
jTextSelectorId = jTextSelector.attr("id");
jTextSelector.autocomplete({
source: serviceUrl,
minLength: minLength,
position: autoCOmpletePosition,
select: function (event, ui) {
jValSelector.val(ui.item.id);
if (selectCallback) {
selectCallback(event, ui);
}
},
response: function (event, ui) {
jQuery.data(jTextSelector[0], jTextSelectorId, ui.content); // Store Filtered result in jQuery data store
}
});
if (secondaryLabel) {
var uiAutoCompleteData = jTextSelector.data("ui-autocomplete");
if (uiAutoCompleteData) {
uiAutoCompleteData._renderItem = function (ul, item) {
return $("<li>")
.append("<a><b>" + item.label + "</b><br><span style='font-size:0.8em;'>" + item.desc + "</span></a>")
.appendTo(ul);
};
}
}
jTextSelector.hover(function () { // On Hover
bindPopOver(this);
jTextSelector.popover('show');
},
function () { // On Unhover
jTextSelector.popover('destroy');
});
function bindPopOver(element) {
if (!$(element).val()) {
jValSelector.val("");
jTextSelector.popover('destroy');
}
else {
var listContent = jQuery.data(jTextSelector[0], jTextSelectorId); // Get Filtered result from jQuery data store
var text = jTextSelector.val();
var item = _.find(listContent, function (itemInList) {
return itemInList.label.toLowerCase() == text.toLowerCase();
});
if (item) {
jValSelector.val(item.id);
jTextSelector.popover('destroy');
jTextSelector.popover({
title: text,
trigger: 'hover',
content: item.desc,
placement: tooltipPlacement
});
}
else if (!item && text == "") {
jValSelector.val("");
jTextSelector.popover('destroy');
}
}
};
},
答案 0 :(得分:0)
您可以使用指令技术从/向DOM组件和angularjs传输数据。
我创建一个简单的代码,可以帮助我们进行绑定。
主要规则是指令的“链接”,辅以“范围”定义来反映外部数据:
scope: { ngMyModel: '=' }
link: function(scope, el, attrs) {
scope.$watch('ngMyModel', function (val) {
el.val(val);
});
el.on('change input', function() {
scope.$apply(function(scope) {
scope.ngMyModel = el.val();
});
});
}
在第一部分我反思输入(或其他组件,如datepicker等)对angularjs数据的任何更改。
在第二部分,我从元素中捕获事件并使用“scope。$ apply”技术来反映angularjs数据。