javascript同步是什么意思,javascript同步和异步的区别与实现方式
今天给各位分享javascript同步是什么意思的知识,其中也会对javascript同步和异步的区别与实现方式进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
如何实现 javascript “同步”调用 app 代码
在 App混合开发中,app层向 js层提供接口有两种方式,一种是同步接口,一种一异步接口(不清楚什么是同步的请看这里的讨论)。为了保证 web流畅,大部分时候,我们应该使用异步接口,但是某些情况下,我们可能更需要同步接口。同步接口的好处在于,首先 js可以通过返回值得到执行结果;其次,在混合式开发中,app层导出的某些 api按照语义就应该是同步的,否则会很奇怪——一个可能在 for循环中使用的,执行非常快的接口,比如读写某个配置项,设计成异步会很奇怪。
那么如何向 js层导出同步接口呢?
我们知道,在 Android框架中,通过 WebView.addJavascriptInterface()这个函数,可以将 java接口导出到 js层,并且这样导出的接口是同步接口。但是在 iOS的 Cocoa框架中,想导出同步接口却不容易,究其原因,是因为 UIWebView和 WKWebView没有 addJavascriptInterface这样的功能。同时,Android这个功能爆出过安全漏洞,那么,我们有没有别的方式实现同步调用呢?我们以 iOS UIWebView为例提供一种实现,WKWebView和 Android也可以参考。
为了找到问题的关键,我们看一下 iOS中实现 js调用 app的通行方法:
首先,自定义 UIWebViewDelegate,在函数 shouldStartLoadWithRequest:navigationType:中拦截请求。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
-(BOOL) webView:(UIWebView* _Nonnull)webView
shouldStartLoadWithRequest:(NSURLRequest* _Nonnull)request
navigationType:(UIWebViewNavigationType)navigationType{
if([request.HTTPMethod compare:@"GET" options:NSCaseInsensitiveSearch]!= NSOrderedSame){
//不处理非 get请求
return YES;
}
NSURL* url= request.URL;
if([url.scheme isEqualToString:@'YourCustomProtocol']){
return [self onMyRequest:request];
}
return YES;
}
这种做法实质上就是将函数调用命令转化为 url,通过请求的方式通知 app层,其中 onMyRequest:是自定义的 request响应函数。为了发送请求,js层要建立一个隐藏的 iframe元素,每次发送请求时修改 iframe元素的 src属性,app即可拦截到相应请求。
1
2
3
4
5
6
7
8
9
10
11
12
13
/**
* js向 native传递消息
*@method js_sendMessageToNativeAsync
*@memberof JSToNativeIOSPolyfill
*@public
*@param str{String}消息字符串,由 HybridMessage转换而来
*/
JSToNativeIOSPolyfill.prototype.js_sendMessageToNativeAsync= function(str){
if(!this.ifr_){
this._prepareIfr();
}
this.ifr_.src='YourCustomProtocol://__message_send__?msg='+ encodeURIComponent(str);}
当 app执行完 js调用的功能,执行结果无法直接返回,为了返回结果,普遍采用回调函数方式——js层记录一个 callback,app通过 UIWebView的 stringByEvaluatingJavaScriptFromString函数调用这个 callback(类似 jsonp的机制)。
注意,这样封装的接口,天然是异步接口。因为 js_sendMessageToNativeAsync这个函数会立即返回,不会等到执行结果发回来。
所以,我们要想办法把 js代码“阻塞”住。
请回忆一下,js中是用什么方法能把 UI线程代码“阻塞”住,同时又不跑满 CPU?
1
2
3
4
var async= false;
var url='http://baidu.com';
var method='GET';<br>var req= new XMLHttpRequest();<br>
req.open(method, url, async);<br>req.send(null);
“同步”ajax(其实没这个词,ajax内涵异步的意思)可以!在 baidu的响应没返回之前,这段代码会一直阻塞。一般来说同步请求是不允许使用的,有导致 UI卡顿的风险。但是在这里因为我们并不会真的去远端请求内容,所以不妨一用。
至此实现方式已经比较清楚了,梳理一下思路:
使用同步 XMLHttpRequest配合特殊构造的 URL通知 app层。
app层拦截请求执行功能,将结果作为 Response返回。
XMLHttpRequest.send()返回,通过 status和 responseText得到结果。
那么,如何拦截请求呢?大家知道,UIWebViewDelegate是不会拦截 XMLHttpRequest请求的,但是 iOS至少给了我们两个位置拦截这类请求——NSURLCache和 NSURLProtocol。
一、NSURLCache是 iOS中用来实现自定义缓存的类,当你创建了自定义的 NSURLCache子类对象,并将其设置为全局缓存管理器,所有的请求都会先到这里检查有无缓存(如果你没禁掉缓存的话)。我们可以借助这个性质拦截到接口调用请求,执行并返回数据。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
-(NSCachedURLResponse*) cachedResponseForRequest:(NSURLRequest*)request{
if([request.HTTPMethod compare:@"GET" options:NSCaseInsensitiveSearch]!= NSOrderedSame){
//只对 get请求做自定义处理
return [super cachedResponseForRequest:request];
}
NSURL* url= request.URL;
NSString* path= url.path;
NSString* query= url.query;
if(path== nil|| query== nil){
return [super cachedResponseForRequest:request];
}
LOGF(@"url=%@, path=%@, query=%@", url, path, query);
if([path isEqualToString:@"__env_get__"]){
//读环境变量
return [self getEnvValueByURL:url];//*
} else if([path isEqualToString:@"__env_set__"]){
//写环境变量
return [self setEnvValueByURL:url];
}
return [super cachedResponseForRequest:request];
}
注意注释有*号的一行,即是执行 app接口,返回结果。这里的结果是一个 NSCachedResponse对象,就不赘述了。
异步加载是什么意思
javascript脚本如何异步加载,有什么作用
使用ajax就可以使用异步加载。推荐使用jquery实现异步加载。使用原生js开发速度会下降很多。
这边有一篇使用jq实现异步加载后台数据。
daimatree/tag_jq/tag_jq_ajax.php
html5手机端异步加载什么意思
异步加载就是在执行过程同时加载,通常会使图片之类重要性较次的东西
基本是用AJAX来进行异步加载。
异步是什么,异步请求呢,异步加载呢,JSON
如果你是同步加载的话,那么你的调用顺序决定了加载顺序,也就是看你这个页面如何解析的顺序,同步加载,只有前面的加载完毕才会执行后面的,否则处于等待状态。如果你是异步调用,各个异步调用之间没有等待关系。虽然也是按照你的页面加载顺序
异步加载的英文怎么说
asynchronous loading
好好学习天天向上
AJAX异步处理是什么意思的?
打个比方吧,通常情况下,用户注册,那么用户首先得填写好表单,然后点提交,这样表单就会向服务发出一个请求叮则服务器处理代码,如果用户存在,则返回一个信息。总之,就是所有的数据需要你点提交后,信息才会发送!
而AJAX就相当于是模拟了一个信息发送请求,你可以在很多网站上注册的时候会发现,比如用户名输入“123”,那么它可能会提示你该用户已经存在,而给你的感觉是页面并没刷新,也就是并没有提交表单,而用户名又是存放在数据库内的,也就是说要查询用户名是否存在,就必须得发送表单的里的用户名,然后再在数据库中去查询。
而这个过程就是用了AJAX来处理的,用户输入用户名,当表单的焦点发生变化的时候,则会触发AJAX,然后AJAX模拟一个GET或者POST请求给服务器,服务器就会处理传递过来的数据!而服务器在处理数据的时候,你可以做其它的,比较你可以填写密码或者其它的!
js怎么异步加载loading
js异步加载loading的方法如下:
1、获取加载的图片
var image= document.images[0];
2、手动创建一个image对象
var downloadingImage= new Image();
3、调用onload事件加载src真正的链接地址
downloadingImage.onload= function(){
image.src= this.src; src后置指定
};
downloadingImage.src="目标图片地址";
android中listview的数据的同步与异步加载有什么区别,效果有什么不同?
目前没有同步加载数据这种做法,如果网络延迟主界面UI就卡死了,
之后用户不耐烦就只能强行关闭了,卡死的时候按键都没反应的。
一个简单的的多线程
class updatelocationTask extends AsyncTask{
protected void onPreExecute(){
这里写执行doInBackground方法之前要做的什么,比如说弹出ProgressDialog
}
}
@Override
protected Response doInBackground(String.场. params){
这里就是线程里面的方法了,比如说建立连接,请求数据
}
}
protected void onPostExecute(Response result){
这里可以根据返回值来确定怎么操作,比如说刷新列表或者提示用户网络不畅,是否再次刷新
}
}
}
}
怎样实现页面的异步加载?
说白了就是无刷新技术
jquery内库已经珐装了ajax的效果我们可以直接拿来用,.ajax.post.get.load
比如说一个点击方法
为什么异步加载js文件?加载方式
同步加载,单步加载,引入js内容可以直接使用
var Skip={};
获取XMLHttpRequest对象(提供客户端同服务器通讯的协议)
Skip.getXmlHttpRequest=function(){
if( window.XMLHttpRequest)除了IE外的其它浏览器
return new XMLHttpRequest();
else if( window.ActiveXObject) IE
return new ActiveXObject("MsXml2.XmlHttp");
},
导入内容
Skip.includeJsText=function(rootObject,jsText){
if( rootObject!= null){
var oScript= document.createElement("script");
oScript.type="text/javascript";
oScript.id= sId;
oScript.src= fileUrl;
oScript.defer= true;
oScript.text= jsText;
rootObject.appendChild(oScript);
alert(oScript.text);
}
在浏览器中基于模块进行JavaScript异步加载有什么意义
主要是提升用户体验,不需要用户等待但又需要与后台交互的时候,用异步加载,在用户感觉上来说,系统就比较流畅.
试想一下:
(1)注册的时候,必须等用户名是否存在的校验做完了,才能填写自己的其他信息
(2)填完用户可以直接填其他信息,等其他信息填完了,提示一下用户已经存在,请修改,然后你去改一下用户名就可以了
作为用户,你喜欢哪一种呢.
javascript同步和异步的区别与实现方式
javascript语言是单线程机制。所谓单线程就是按次序执行,执行完一个任务再执行下一个。
对于浏览器来说,也就是无法在渲染页面的同时执行代码。
单线程机制的优点在于实现起来较为简单,运行环境相对简单。缺点在于,如果中间有任务需要响应时间过长,经常会导致
页面加载错误或者浏览器无响应的状况。这就是所谓的“同步模式”,程序执行顺序与任务排列顺序一致。对于浏览器来说,
同步模式效率较低,耗时长的任务都应该使用异步模式;而在服务器端,异步模式则是唯一的模式,如果采用同步模式个人认为
服务器很快就会出现12306在高峰期的表现。。。。
异步模式的四种方式:
1.回调函数callback
所谓回调函数,就是将函数作为参数传到需要回调的函数内部再执行。
典型的例子就是发送ajax请求。例如:
$.ajax({
async: false,
cache: false,
dataType:'json',
url:"url",
success: function(data){
console.log('success');
},
error: function(data){
console.log('error');
}
})
当发送ajax请求后,等待回应的过程不会堵塞程序运行,耗时的操作相当于延后执行。
回调函数的优点在于简单,容易理解,但是可读性较差,耦合度较高,不易于维护。
2.事件驱动
javascript可以称之为是基于对象的语言,而基于对象的基本特征就是事件驱动(Event-Driven)。
事件驱动,指的是由鼠标和热键的动作引发的一连串的程序操作。
例如,为页面上的某个
$('#btn').onclick(function(){
console.log('click button');
});
绑定事件相当于在元素上进行监听,是否执行注册的事件代码取决于事件是否发生。
优点在于容易理解,一个元素上可以绑定多个事件,有利于实现模块化;但是缺点在于称为事件驱动的模型后,流程不清晰。
3.发布/订阅
发布订阅模式(publish-subscribe pattern)又称为观察者模式(Observer pattern)。
该模式中,有两类对象:观察者和目标对象。目标对象中存在着一份观察者的列表,当目标对象
的状态发生改变时,主动通知观察者,从而建立一种发布/订阅的关系。
jquery有相关的插件,在这不是重点不细说了。。。。回头写个实现贴上来
4.promise模式
promise对象是CommonJS工作组提供的一种规范,用于异步编程的统一接口。
promise对象通常实现一种then的方法,用来在注册状态发生改变时作为对应的回调函数。
promise模式在任何时刻都处于以下三种状态之一:未完成(unfulfilled)、已完成(resolved)和拒绝(rejected)。以CommonJS
Promise/A
标准为例,promise对象上的then方法负责添加针对已完成和拒绝状态下的处理函数。then方法会返回另一个promise对象,以便于形成promise管道,这种返回promise对象的方式能够支持开发人员把异步操作串联起来,如then(resolvedHandler,
rejectedHandler);。resolvedHandler
回调函数在promise对象进入完成状态时会触发,并传递结果;rejectedHandler函数会在拒绝状态下调用。
Jquery在1.5的版本中引入了一个新的概念叫Deferred,就是CommonJS promise A标准的一种衍生。可以在jQuery中创建
$.Deferref的对象。同时也对发送ajax请求以及数据类型有了新的修改,参考JQuery API。
除了以上四种,javascript中还可以利用各种函数模拟异步方式,更有诡异的诸如用同步调用异步的case
只能用team里同事形容java和javascript的一句话作为结尾:
“写java像在高速路上开车,写javascript像在草原上开车”-------------以此来形容javascript这种无类型的语言有多自由
but,如果草原上都是坑。
好了,关于javascript同步是什么意思和javascript同步和异步的区别与实现方式的问题到这里结束啦,希望可以解决您的问题哈!