本文整理匯總了TypeScript中source-mutation.eachArrayValueMutation函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript eachArrayValueMutation函數的具體用法?TypeScript eachArrayValueMutation怎麽用?TypeScript eachArrayValueMutation使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了eachArrayValueMutation函數的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: eachArrayValueMutation
const diffCSSGroupingRuleChildren = (oldRule: SlimCSSGroupingRule, newRule: SlimCSSGroupingRule, path: any[]) => {
const diffs: Mutation<any[]>[] = [];
eachArrayValueMutation(
diffArray(oldRule.rules, newRule.rules, compareCSSRules),
{
insert({ index, value }) {
diffs.push(createInsertChildMutation(CSS_INSERT_RULE, path, compressRootNode(value), index));
},
delete({ index }) {
diffs.push(createRemoveChildMutation(CSS_DELETE_RULE, path, null, index));
},
update({ newValue, originalOldIndex, index, patchedOldIndex }) {
if (index !== patchedOldIndex) {
diffs.push(createMoveChildMutation(CSS_MOVE_RULE, path, null, index, patchedOldIndex));
}
diffs.push(
...diffCSSRule(
oldRule.rules[originalOldIndex],
newValue,
[...path, index]
)
);
}
}
);
return diffs;
};
示例2: diffArray
export const diffParentNode = (oldNode: BasicParentNode, newNode: BasicParentNode, diffChildNode: (oldChild: BasicNode, newChild: BasicNode) => Mutation<any>[]) => {
const mutations = [];
const diff = diffArray(Array.from(oldNode.childNodes), Array.from(newNode.childNodes), (oldNode, newNode) => {
if (oldNode.nodeName !== newNode.nodeName || oldNode.namespaceURI !== newNode.namespaceURI) return -1;
return 1;
});
eachArrayValueMutation(diff, {
insert({ index, value }) {
mutations.push(createParentNodeInsertChildMutation(oldNode, value, index));
},
delete({ index }) {
mutations.push(createParentNodeRemoveChildMutation(oldNode, oldNode.childNodes[index]));
},
update({ originalOldIndex, patchedOldIndex, newValue, index }) {
if (patchedOldIndex !== index) {
mutations.push(createParentNodeMoveChildMutation(oldNode, oldNode.childNodes[originalOldIndex], index, patchedOldIndex));
}
const oldValue = oldNode.childNodes[originalOldIndex];
mutations.push(...diffChildNode(oldValue, newValue));
}
});
mutations.push(...diffNodeBase(oldNode as any as SEnvNodeInterface, newNode as any as SEnvNodeInterface));
return mutations;
};
示例3: update
update() {
if (this._stale) {
this._stale = false;
const diff = diffArray(
this,
Array.prototype.filter.call(this._target.childNodes, a => a.nodeType === SEnvNodeTypes.ELEMENT),
(a, b) => a === b ? 0 : -1
);
eachArrayValueMutation(diff, {
insert: ({ value, index }) => {
this.splice(index, 0, value);
},
delete: ({ index }) => {
this.splice(index, 1);
},
update() {
}
});
}
return this;
}