$.ajax({url: 'http://gmaps-samples-v3.googlecode.com/svn-history/r16/trunk/xmlparsing/util.js', dataType: 'script text text', crossdomain:'true', success: function(msg, status, obj){console.log(msg);console.log(status);console.log(obj)}, mimetype: 'text/plain', cache:false});
我尝试运行上面的代码及其变体 - 删除mimetype,缓存,将dataType设置为'script text'和'script script text'。
直接来自jQuery文档:
多个空格分隔的值:As jQuery 1.5,jQuery可以转换一个 dataType来自它收到的内容 Content-Type标题给你 要求。例如,如果你想要一个 文本响应被视为XML, 使用“text xml”作为dataType。您 也可以发出JSONP请求 作为文本接收,并由 jQuery as XML:“jsonp text xml。” 同样,一个速记字符串如 “jsonp xml”将首先尝试 从jsonp转换为xml,和 失败,从jsonp转换为 文本,然后从文本到xml
我仅限于发出'script'类型的dataType请求,否则我得到一个“...... Access-Control-Allow-Origin不允许”错误。但是根据所有权利,我不应该自由地在jQuery中解释它,但是我想要吗?我已明确要求它作为文本,但msg - 来自服务器的返回数据 - 总是“未定义”,无论我做什么。
是否有任何解决方法,hacky与否?
编辑:此代码有效,因为它会加载JavaScript文件并将其下载到用户的浏览器中。但我仍然无法查看它!
答案 0 :(得分:2)
但是根据所有权利,我不应该自由地在jQuery中解释它但是我想要吗?
浏览器中的安全机制阻止您这样做,因为它允许您从其他网站窃取用户的私人信息。如果您在脚本启用时向同一域发出请求,它将起作用。否则,您无法在JavaScript中发出请求,而是需要从服务器进行请求。
答案 1 :(得分:0)
请注意我正在使用jQuery 1.6.1和jQuery Mobile 1.0a4.1以及PhoneGap。
您的dataType应为“text”而不是“script text text”:
$.ajax({url: 'http://gmaps-samples-v3.googlecode.com/svn-history/r16/trunk/xmlparsing/util.js', dataType: 'text', crossdomain:'true', success: function(msg, status, obj){console.log(msg);console.log(status);console.log(obj)}, mimetype: 'text/plain', cache:false});
此命令工作正常,并在日志中返回以下内容:
D/PhoneGapLog( 240): file:///android_asset/www/js/myJSFile.js: Line 1 : /
**
D/PhoneGapLog( 240): * Returns an XMLHttp instance to use for asynchronous
D/PhoneGapLog( 240): * downloading. This method will never throw an exception,
but will
D/PhoneGapLog( 240): * return NULL if the browser does not support XmlHttp for
any reason.
D/PhoneGapLog( 240): * @return {XMLHttpRequest|Null}
D/PhoneGapLog( 240): */
D/PhoneGapLog( 240): function createXmlHttpRequest() {
D/PhoneGapLog( 240): try {
D/PhoneGapLog( 240): if (typeof ActiveXObject != 'undefined') {
D/PhoneGapLog( 240): return new ActiveXObject('Microsoft.XMLHTTP');
D/PhoneGapLog( 240): } else if (window["XMLHttpRequest"]) {
D/PhoneGapLog( 240): return new XMLHttpRequest();
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): } catch (e) {
D/PhoneGapLog( 240): changeStatus(e);
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): return null;
D/PhoneGapLog( 240): };
D/PhoneGapLog( 240):
D/PhoneGapLog( 240): /**
D/PhoneGapLog( 240): * This functions wraps XMLHttpRequest open/send function.
D/PhoneGapLog( 240): * It lets you specify a URL and will call the callback if
D/PhoneGapLog( 240): * it gets a status code of 200.
D/PhoneGapLog( 240): * @param {String} url The URL to retrieve
D/PhoneGapLog( 240): * @param {Function} callback The function to call once ret
rieved.
D/PhoneGapLog( 240): */
D/PhoneGapLog( 240): function downloadUrl(url, callback) {
D/PhoneGapLog( 240): var status = -1;
D/PhoneGapLog( 240): var request = createXmlHttpRequest();
D/PhoneGapLog( 240): if (!request) {
D/PhoneGapLog( 240): return false;
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240):
D/PhoneGapLog( 240): request.onreadystatechange = function() {
D/PhoneGapLog( 240): if (request.readyState == 4) {
D/PhoneGapLog( 240): try {
D/PhoneGapLog( 240): status = request.status;
D/PhoneGapLog( 240): } catch (e) {
D/PhoneGapLog( 240): // Usually indicates request timed out in FF.
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): if (status == 200) {
D/PhoneGapLog( 240): callback(request.responseXML, request.status);
D/PhoneGapLog( 240): request.onreadystatechange = function() {};
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): request.open('GET', url, true);
D/PhoneGapLog( 240): try {
D/PhoneGapLog( 240): request.send(null);
D/PhoneGapLog( 240): } catch (e) {
D/PhoneGapLog( 240): changeStatus(e);
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240): };
D/PhoneGapLog( 240):
D/PhoneGapLog( 240): /**
D/PhoneGapLog( 240): * Parses the given XML string and returns the parsed docu
ment in a
D/PhoneGapLog( 240): * DOM data structure. This function will return an empty
DOM node if
D/PhoneGapLog( 240): * XML parsing is not supported in this browser.
D/PhoneGapLog( 240): * @param {string} str XML string.
D/PhoneGapLog( 240): * @return {Element|Document} DOM.
D/PhoneGapLog( 240): */
D/PhoneGapLog( 240): function xmlParse(str) {
D/PhoneGapLog( 240): if (typeof ActiveXObject != 'undefined' && typeof GetObj
ect != 'undefined') {
D/PhoneGapLog( 240): var doc = new ActiveXObject('Microsoft.XMLDOM');
D/PhoneGapLog( 240): doc.loadXML(str);
D/PhoneGapLog( 240): return doc;
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240):
D/PhoneGapLog( 240): if (typeof DOMParser != 'undefined') {
D/PhoneGapLog( 240): return (new DOMParser()).parseFromString(str, 'text/xm
l');
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240):
D/PhoneGapLog( 240): return createElement('div', null);
D/PhoneGapLog( 240): }
D/PhoneGapLog( 240):
D/PhoneGapLog( 240): /**
D/PhoneGapLog( 240): * Appends a JavaScript file to the page.
D/PhoneGapLog( 240): * @param {string} url
D/PhoneGapLog( 240): */
D/PhoneGapLog( 240): function downloadScript(url) {
D/PhoneGapLog( 240): var script = document.createElement('script');
D/PhoneGapLog( 240): script.src = url;
D/PhoneGapLog( 240): document.body.appendChild(script);
D/PhoneGapLog( 240): }