问题描述
|
$.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 Docs:
多个以空格分隔的值:
jQuery 1.5版本,jQuery可以将
dataType来自它在
Content-Type标头指向您所要
要求。例如,如果您想要
文本响应被视为XML,
使用\“ text xml \”作为dataType。您
也可以发出JSONP请求
接收为文本,并由
jQuery作为XML:\“ jsonp文本xml。\”
同样,速记字符串如
\“ jsonp xml \”将首先尝试
从jsonp转换为xml,然后,
失败的话,从jsonp转换为
文本,然后从文本到xml
我仅限于发出类型为\'script \'的dataType请求,否则我将收到\“ ... Access-Control-Allow-Origin \不允许的错误”。但是从所有的权利来看,我是否应该随心所欲地在jQuery中解释它?我已经明确要求将其作为文本,但是无论我做什么,msg(从服务器返回的数据)始终为“未定义”。
有没有针对性的解决方法,无论是hacky还是否?
编辑:此代码的工作方式是加载JavaScript文件并将其下载到用户的浏览器。但是我还是看不到它!
解决方法
但是从所有的权利来看,我是否应该随心所欲地在jQuery中解释它?
浏览器中的安全机制阻止您执行此操作,因为它可以使您从其他网站窃取用户的私人信息。如果您要向与脚本所在的域相同的域发出请求,则该请求将起作用。否则,您将无法使用JavaScript发出请求,而需要从服务器发出请求。
, 请注意,我将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): }