本文整理汇总了TypeScript中knockout.utils.extend方法的典型用法代码示例。如果您正苦于以下问题:TypeScript utils.extend方法的具体用法?TypeScript utils.extend怎么用?TypeScript utils.extend使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类knockout.utils
的用法示例。
在下文中一共展示了utils.extend方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: function
function history<T>(initialValue?: T): history.HistoryObservable<T> {
const self = {
latestValues: ko.observableArray([initialValue]),
selectedIndex: ko.observable(0),
canGoBack: ko.pureComputed(() => self.selectedIndex() > 0),
canGoNext: ko.pureComputed(() => self.selectedIndex() < self.latestValues().length - 1)
} as any;
ko.utils.extend(self, history.fn);
const result: any = ko.pureComputed({
read: () => {
const values = self.latestValues();
let index = self.selectedIndex();
if (index > values.length) {
index = 0;
}
return values[index];
},
write: (value: any) => {
const
index = self.selectedIndex(),
values = self.latestValues();
if (value !== values[index]) {
if (index !== values.length - 1) {
values.splice(index + 1);
}
values.push(value);
self.selectedIndex(index + 1);
}
}
}).extend({ notify: "reference" });
ko.utils.extend(result, self);
const oldDispose = result.dispose;
result.dispose = function () {
oldDispose.call(this);
this.canGoBack.dispose();
this.canGoNext.dispose();
};
return result;
}
示例2: function
init: function (element, valueAccessor) {
const $element = $(element);
let value = valueAccessor(),
options = ko.unwrap(value),
id = $element.attr("id"),
oldSetup, editor;
if (typeof options === "object") {
value = options.value;
delete options.value;
}
else {
options = {};
}
if (!id) {
id = tinymce.DOM.uniqueId();
$element.attr("id", id);
}
ko.utils.extend(options, defaults);
oldSetup = options.setup;
options.setup = (editor) => {
oldSetup && oldSetup.call(undefined, editor);
};
if ($element.is("textarea"))
$element.val(ko.unwrap(value));
else {
$element.html(ko.unwrap(value));
options.inline = true;
}
editor = new tinymce.Editor(id, options, tinymce.EditorManager);
editor.on("change keyup nodechange", () => {
if (ko.isWriteableObservable(value)) value(editor.getContent());
});
// To prevent a memory leak, ensure that the underlying element"s disposal destroys it"s associated editor.
ko.utils.domNodeDisposal.addDisposeCallback(element, () => {
if (editor) {
editor.remove();
editor = null;
}
});
editor.render();
},
示例3: trigger
export function trigger(element: HTMLElement, eventType: string, eventArgs: any): void {
let evt;
if (doc.createEvent) {
evt = doc.createEvent("HTMLEvents");
evt.initEvent(eventType, true, true);
} else {
evt = doc.createEventObject();
evt.eventType = eventType;
}
evt.eventName = eventType;
ko.utils.extend(evt, eventArgs);
if (doc.createEvent) {
element.dispatchEvent(evt);
} else {
element.fireEvent("on" + evt.eventType, evt);
}
}
示例4:
crossroads.addRoute(route.url,(requestParams) => {
this.currentRoute(ko.utils.extend(requestParams, route.params));
});