- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想要一些有关“组合”框的 Select/Select2 功能的帮助,我正在尝试使用 knockout/jquery 在 .Net 中设置该框。我需要用一组值预加载此“组合”框,然后允许用户添加其他条目(从下拉列表中选择或输入其他内容)或删除条目。只要预加载到“组合”框中的值存在于协调下拉列表(所有用户)中,下面的代码就可以正常工作。如果下拉列表中不存在预加载的值,它们就会被绕过。
还有其他人必须处理这个问题吗?你是如何克服的?如果有任何反馈或想法,我将不胜感激!
<select data-bind="selectedOptions: newMessageTo, optionsCaption: 'Select a user...',
options: allUsers, optionsText: 'userName', optionsValue: 'userName',
select2: { placeholder: 'Select a user...', allowClear: true, multiple: true,
minimumInputLength: 3, tags: true, minimumResultsForSearch: 20 }">
</select>
self.myMessage = ko.observable({});
self.myMessageText = ko.observable("");
self.messageId = ko.observable({});
self.newMessageText = ko.observable("");
self.newMessageTo = ko.observableArray([]);
self.newMessageSubject = ko.observable("");
self.newAttachment = ko.observable({});
self.newAttachmentList = ko.observableArray([]);
self.allUsers = ko.observable({});
self.bearer = ko.observable();
self.newStyleAttachments = ko.observable(false);
self.replyAll = function () {
self.replying() ? self.replying(false) : self.replying(true);
self.newMessageTo.removeAll();
for (var i = 0; i < self.myMessage().cc.length; i++) {
if (self.myMessage().cc[i] !== self.user.email) {
self.newMessageTo.push(self.myMessage().cc[i]);
}
}
self.newMessageTo.push(self.myMessage().senderEmail);
self.newMessageText("<br/><center>-------------------------------------------</center><br/> \
<b>From:</b> " + self.myMessage().senderEmail + " <br/><b>To:</b> " + self.myMessage().cc + " \
<br/><b>Subject:</b> " + self.myMessage().messageSubject + "<br/>" + self.myMessageText());
self.newMessageSubject("RE: " + self.myMessage().messageSubject);
};
ko.bindingHandlers.select2 = {
init: function (el, valueAccessor, allBindingsAccessor, viewModel) {
ko.utils.domNodeDisposal.addDisposeCallback(el, function () {
$(el).select2('destroy');
});
var allBindings = allBindingsAccessor(),
select2 = ko.utils.unwrapObservable(allBindings.select2);
$(el).select2(select2);
},
update: function (el, valueAccessor, allBindingsAccessor, viewModel) {
var allBindings = allBindingsAccessor();
if ("value" in allBindings) {
if ((allBindings.select2.multiple || el.multiple) && allBindings.value().constructor != Array) {
$(el).val(allBindings.value().split(',')).change();
}
else {
$(el).val(allBindings.value()).change();
}
} else if ("selectedOptions" in allBindings) {
var converted = [];
var textAccessor = function (value) { return value; };
if ("optionsText" in allBindings) {
textAccessor = function (value) {
var valueAccessor = function (item) { return item; }
if ("optionsValue" in allBindings) {
valueAccessor = function (item) { return item[allBindings.optionsValue]; }
}
var items = $.grep(allBindings.options(), function (e) { return valueAccessor(e) == value });
if (items.length == 0 || items.length > 1) {
return "UNKNOWN";
}
return items[0][allBindings.optionsText];
}
}
$.each(allBindings.selectedOptions(), function (key, value) {
converted.push({ id: value, text: textAccessor(value) });
});
$(el).select2("data", converted);
}
$(el).change();
}
};
最佳答案
我的猜测是,这与您的 select2
knockout 绑定(bind)有关(问题中不存在)。
下面是一个工作示例,其中包含一个非常简单的绑定(bind)处理程序,取自 here 。只需运行代码片段,该代码片段会预先填充 2 个选项和 1 个值的下拉列表,然后(5 秒后)向其中添加 2 个值 - 一个作为选项存在,另一个则不存在(因此也添加了作为一个新选项):
$(document).ready(function () {
registerBinding();
run();
});
var vm = function () {
var self = this;
self.available = ko.observableArray(['John', 'Joe']);
self.selected = ko.observableArray(['John']);
self.add = function (otherUsers) {
otherUsers.forEach(function (otherUser) {
var matchedAvailable = self.match(self.available(), otherUser);
var matchedSelected = self.match(self.selected(), otherUser);
if (!matchedAvailable) {
self.available.push(otherUser);
}
if (!matchedSelected) {
self.selected.push(otherUser);
}
});
};
self.match = function (users, userToMatch) {
var matched = ko.utils.arrayFirst(users, function (user) {
return user == userToMatch;
});
return matched;
};
};
function run() {
var vmInstance = new vm();
ko.applyBindings(vmInstance);
setTimeout(function () {
vmInstance.add(['Jane', 'Joe']);
}, 5000);
}
function registerBinding() {
ko.bindingHandlers.select2 = {
after: ["options", "value"],
init: function (el, valueAccessor, allBindingsAccessor, viewModel) {
$(el).select2(ko.unwrap(valueAccessor()));
ko.utils.domNodeDisposal.addDisposeCallback(el, function () {
$(el).select2('destroy');
});
},
update: function (el, valueAccessor, allBindingsAccessor, viewModel) {
var allBindings = allBindingsAccessor();
var select2 = $(el).data("select2");
if ("value" in allBindings) {
var newValue = "" + ko.unwrap(allBindings.value);
if ((allBindings.select2.multiple || el.multiple) && newValue.constructor !== Array) {
select2.val([newValue.split(",")]);
}
else {
select2.val([newValue]);
}
}
}
}
};
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.12/js/select2.full.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" />
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.12/css/select2.min.css" />
<div class="col-xs-4">
<label for="users">Users</label>
<select id="users" class="form-control"
multiple="multiple"
data-bind="options: available,
selectedOptions: selected,
select2: { placeholder: 'Select an option...', allowClear: true }">
</select>
</div>
关于javascript - .Net Select/Select2 knockout javascript - 如果初始值不在下拉列表中,则无法加载初始值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59842041/
我有一个 MvvmCross MvxSpinner在 Android 中绑定(bind)。用户选择一个值并反射(reflect)在我的属性 MealTypeSelected . 微调器允许用户选择膳
我有一个带有某种类型函数指针的公共(public)变量的表单,如下所示: {...} interface type TExternalFunction = function(var x : TAn
this question中的答案对我理解如何在 IBAction 方法中检索步进器值很有帮助(我投了赞成票),但我仍然不理解在我第一次加载 View 时如何获取步进器的初始值。 我想将初始值设置为
Apple 文档指出: The willSet and didSet observers of superclass properties are called when a property is
我正在将 ColdFusion 应用程序转换为 C#(我是 CF n00b)。 我有一个脚本执行 cfquery,然后执行 cfloop 的结果,它似乎试图将当前行与其下一行进行比较。它似乎试图确保它
我在为 antd 动态表单设置初始值时遇到问题。有什么方法可以在动态中初始化值吗?它需要使用 getFieldDecorator 注册字段。但对于动态字段,该字段之前没有注册。 我收到这个错误:不能在
是否可以动态地为 forms.FileField() 赋予初始值? 最佳答案 我不确定,如果这就是你想要的,但是…… 显然,您不能为文件输入设置初始数据(这意味着您将文件发送给用户)。 Django
我对 Django 表单中 DateTimeField 的初始值没有什么问题。 我在 forms.py 中有声明 class FaultForm(forms.ModelForm): ...
如何使用代码设置 slider 初始值?我知道如何在属性检查器中执行此操作。我想在我的应用程序启动时使用“UserDefault”作为初始值,当我的应用程序第一次启动时,我想将初始值设置为“1.0”
我有一个 RadioButton其 IsChecked 的元素属性绑定(bind)到 MyProperty在 ViewModel . Binding有模式OneWayToSource由于某些原因,它会
我有一个ViewModel类,看起来像这样: class EditUserViewModel( private val initUser: User, ) : ViewModel() {
有人可以帮我解决我的问题吗,问题是我希望我输入到文本字段的第一个初始值只是从 1 到 9 的数字,我正在使用小数垫,所以我也不希望我的初始值是小数点,但在第一个值(仅从 1 t0 9 开始的数字)之后
我正在使用 NSFetchedResultsController 从 CoreData 获取数据并加载包含四个部分的 TableView 。当应用程序第一次运行时,它可以完美地工作,将 plist 加
使用 primeNg 下拉组件,我试图用初始值初始化下拉列表,但没有成功,我使用的是响应式(Reactive)方法。 我检查了 primeNg 文档和演示 - 几乎所有示例都使用模板驱动,我希望模型驱
如何在 ASP.NET 中设置数据绑定(bind)下拉列表的初始值? 例如,我想要这些值,但要显示的第一个值应该是 -- Select One ---,且值为空。 最佳答案 我想你想做的是这样的:
我知道我不能给 BehaviorSubject一个 Observable 值,但我需要一种方法来解决这个问题。在应用程序初始化时,我正在获取当前用户(如果存在),我需要提供 BehaviorSubje
这是我在这里的第一篇文章,所以我希望它是全面的。 我正在使用 AngularJs,并且我使用 Angular 指令添加了一个 JqueryUI slider 。我找到了很多关于如何做到这一点的例子,但
如何有效地为大型数组分配一个公共(public)初始值?例如,如果我有一个 100 x 100 x 100 的整数数组,其中所有初始值都应为零。 在 matlab 中我会简单地写: array = z
我正在为 iOS 应用程序创建一个 Pebble 配套应用程序。我已经使用一些初始值设置了我的 AppSync: Tuplet initial_values[] = { TupletC
有件事我迟到了: const [object, setObject] = useState(new SomeObject()); 在这里,我们在每次重新渲染上构造一个SomeObject实例。然后,如
我是一名优秀的程序员,十分优秀!