确实!您描述的场景实际上是该平台最初设计的主要插件类型之一。关键元素是一个 JavaScript 对象,我们称之为“绑定”,它跟踪文档中的内容控件,并且不需要 OXML 或自定义 XML。
API 能够直接添加内容控件(类似于文本框):调用Bindings.addFromSelectionAsync方法。
function addNewField(fieldName){
Office.context.document.bindings.addFromSelectionAsync("text",
{ id: fieldName },
function (asyncResult){
displayNumberFromDatabase(asyncResult.value);
}
}
还要注册两个事件处理程序,以便在用户选择或修改这些内容控件中的文本时收到通知。这种情况下的相关事件分别是BindingSelectionChanged和BindingDataChanged。
Office.context.document.addHandlerAsync("bindingDataChanged", whenBindingDataChanged);
Office.context.document.addHandlerAsync("bindingSelectionChanged", whenBindingSelected);
当这些事件被触发时,你会想要阅读内容。您可以使用Binding.getDataAsync方法来做到这一点。
function whenBindingDataChanged(eventArgs){
eventArgs.binding.getDataAsync(function(asyncResult){
setValueToDatabaseAsync(eventArgs.binding.id,asyncResult.value);
// you need to implement setValueToDatabaseAsync
});
}
最后,要自己修改Binding的内容,写入初始值,使用Binding.setDataAsync方法。
function displayNumberFromDatabase(myBinding){
getValueFromDatabaseAsync(myBinding.id, function(value){
myBinding.setDataAsync(value);
});
// you need to implement getValueFromDatabaseAsync
}
-Michael Saunders,Office 插件的 PM