我正在尝试通过单击按钮来解析XML文档树。在一个查找函数中获取XML文件,该函数接受两个值("id“和"shipping")并将其附加到适当的URL上,然后JSON.parse将相关数据附加到适当的文本字段"address”中。我需要用这个解析的结果动态地填充另一个输入行,但是URLFetch只在code.gs端可用。有没有办法将数组从gs端传递到我的Javascript端,或者我最好的选择是XMLHttpRequest函数?
我已经尝试了在js端获取url,以及一个新的函数"httpGet“。
URLFetch函数:
document.getElementById('lookup').addEventListener('click',patientLookup);
function personLookup(){
var patient = document.getElementById('id').value;
var shippingStyle = document.getElementById('shipping').value;
var address = document.getElementById('address');
var url = "someurl?patientID=" + patient;
var shippingAddress = UrlFetchApp.fetch(url,{'muteHttpExceptions':true});
Console.log(shippingAddress)
var addressData = JSON.parse(shippingAddress.getContentText());
var shipAdd = addressData.Address;
var city = addressData.City;
var state = addressData.State;
var zip = addressData.Zip;
address.value = shipAdd + "," + city + "," + state + "," + zip;
};HttpGet函数:
function httpGet(theUrl)
{
var xmlHttp = new XMLHttpRequest();
xmlHttp.open( "GET", theUrl, false ); // false for synchronous
request
xmlHttp.send( null );
return xmlHttp.responseText;
} 显然,错误是URLFetch只在gs端被支持,然后httpGet函数不能按照我需要的方式工作,我也不像fetch函数那样熟悉这样的函数。
发布于 2019-08-30 22:36:27
您需要在GS端编写函数,然后通过google.script.run.googleScriptFunction( id,shipping)将变量传递给它,其中id和shipping是您想要传递给google script函数的值。
你可能会发现这个documentation很有帮助
https://stackoverflow.com/questions/57728304
复制相似问题