Android模仿jquery异步请求
01 |
package com.xbl.task; |
02 |
03 |
import java.io.BufferedReader; |
04 |
import java.io.InputStream; |
05 |
import java.io.InputStreamReader; |
06 |
import java.net.URL; |
07 |
import java.util.concurrent.Executor; |
08 |
import java.util.concurrent.ExecutorService; |
09 |
import java.util.concurrent.Executors; |
10 |
11 |
import android.os.Bundle; |
12 |
import android.os.Handler; |
13 |
import android.os.Message; |
14 |
import android.util.Log; |
15 |
16 |
17 |
public class JQuery { |
18 |
|
19 |
private static final String KEY = "key" ; |
20 |
private static String TAG = "JQuery" ; |
21 |
private static final int N = 5 ; // 5个工人 |
22 |
private static final Executor worker = Executors.newFixedThreadPool(N); // 线程池 |
23 |
private static final Handler handler = new Handler(){ |
24 |
@Override |
25 |
public void handleMessage(Message msg) { |
26 |
TaskListener listener = (TaskListener)msg.obj; |
27 |
Object result = msg.getData(); |
28 |
if (listener != null ){ |
29 |
listener.callBack(result); |
30 |
} |
31 |
destory(); |
32 |
} |
33 |
}; |
34 |
|
35 |
private JQuery(){ |
36 |
} |
37 |
|
38 |
public static void execute( final String url, final TaskListener listener){ |
39 |
worker.execute( new Runnable() { |
40 |
@Override |
41 |
public void run() { |
42 |
String result = null ; |
43 |
try { |
44 |
result = WebUtil.get(url); |
45 |
} catch (Exception e) { |
46 |
Log.e(TAG, e.getMessage()); |
47 |
} |
48 |
|
49 |
Message msg = new Message(); |
50 |
Bundle data = new Bundle(); |
51 |
data.putSerializable(KEY, result); |
52 |
msg.setData(data); |
53 |
msg.obj = listener; |
54 |
handler.sendMessage(msg); |
55 |
} |
56 |
}); |
57 |
} |
58 |
|
59 |
//销毁线程 |
60 |
private static void destory() { |
61 |
if (worker != null && worker instanceof ExecutorService) { |
62 |
ExecutorService es = (ExecutorService) worker; |
63 |
if (!es.isShutdown()) { |
64 |
es.shutdown(); |
65 |
} |
66 |
} |
67 |
} |
68 |
|
69 |
public interface TaskListener{ |
70 |
public void callBack(Object result); |
71 |
} |
72 |
/** |
73 |
* |
74 |
* 不必太在意此处代码,只是示例 |
75 |
* |
76 |
*/ |
77 |
public static class WebUtil{ |
78 |
|
79 |
public static String get(String url) throws Exception{ |
80 |
InputStream inputStream = new URL(url).openStream(); |
81 |
StringBuilder strBuilder = new StringBuilder(); |
82 |
BufferedReader reader = new BufferedReader( new InputStreamReader(inputStream)); |
83 |
for (String s = reader.readLine(); s != null ; s = reader.readLine()) |
84 |
strBuilder.append(s); |
85 |
|
86 |
inputStream.close(); |
87 |
return strBuilder.toString(); |
88 |
} |
89 |
} |
90 |
} |
2. [代码][Java]代码
01 |
//调用方法: |
02 |
JQuery.execute( "http://weather.news.qq.com/inc/minisite_125.js" , new JQuery.TaskListener() { |
03 |
@Override |
04 |
public void callBack(Object result) { |
05 |
TextView t = new TextView(TaskDemoActivity. this ); |
06 |
t.setText(String.valueOf(result)); |
07 |
LinearLayout layout = (LinearLayout)findViewById(R.id.layout1); |
08 |
layout.addView(t); |
09 |
} |
10 |
}); |
Android模仿jquery异步请求的更多相关文章
- jQuery异步请求(如getJSON)跨域解决方案
相信大家在使用jQuery异步请求非自己网站内相对资源(通过别人站点上的URL直接读取)使经常会遇到如下错误吧,实际上这些错误都是浏览器安全机制“搞的鬼”,才让我们开发路上遇到了拦路虎. 当你直接在浏 ...
- jQuery异步请求模拟IE登录网站
具体请求的登录验证页面后台逻辑处理,这里我们忽略,不在我们的学习范围内:关键的是使用jQuery异步请求方法,如下例子: <%@ Page Language="C#" Aut ...
- 实现在Android简单封装类似JQuery异步请求
在android开发中经常会使用异步请求数据,通常会使用handler或者AsyncTask去做,handler 配合message 使用起来比较麻烦,AsyncTask 线程池只允许128个线程工作 ...
- Android简单封装类似JQuery异步请求
在android开发中经常会使用异步请求数据,通常会使用handler或者AsyncTask去做,handler 配合message 使用起来比较麻烦,AsyncTask 线程池只允许128个线程工作 ...
- Android 的图片异步请求加三级缓存 ACE
使用xUtils等框架是很方便,但今天要用代码实现bitmapUtils 的功能,很简单, 1 AsyncTask请求一张图片 ####AsyncTask #####AsyncTask是线程池+han ...
- Jquery异步请求简单实例(转)
本文引用自Xingsoft. 一.Jquery向aspx页面请求数据 前台页面JS代码: $("#Button1").bind("click&qu ...
- Jquery异步请求数据实例
一.Jquery向aspx页面请求数据 前台页面JS代码: $("#Button1").bind("click", function () { $.ajax({ ...
- Jquery异步请求数据实例代码
一.Jquery向aspx页面请求数据 前台页面JS代码: 代码如下: $("#Button1").bind("click", function () { $. ...
- jQuery异步请求ajax()之complete参数详解
请求完成后回调函数 (请求success 和 error之后均调用).这个回调函数得到2个参数:XMLHTTPRequest) 对象和一个描述请求状态的字符串("success", ...
随机推荐
- document.documentElement和document.body区别
body是DOM对象里的body子节点,即body标签, documentElement 是整个节点树的根节点root, 详细介绍请看本文,感兴趣的朋友可以参考下 区别: body是DOM对象里的 ...
- (转)ASP.NET版本的Kindeditor插件的使用(同步)
昨天老大让我自己下载一个kindeditor说要放到“描述”功能中,并且不能提交(一边在textarea中写一边在label控件中将数据显示出来),由于从来没弄过,实在费了一翻劲.所以将此记录下来,一 ...
- How to start the Virtualbox VMs under terminal
Since we have servral machine on my testbed(fedora), and if I need start some VMs on that, I have to ...
- 在iOS虚拟机上使CLPlacemark获取中文信息
-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations{ CLLocat ...
- MySQL 覆盖索引
通常大家都会根据查询的WHERE 条件来穿件合适的索引,不过这只是索引优化的一个方面.设计优秀的索引应该考虑到整个查询,而不单单是WHERE 条件部分.索引确实是一种查找数据的高效方式,但是MySQL ...
- 利用css进行网页布局
网页布局: 又称版式布局,是网页UI设计师将有限的视觉元素进行有机的排列组合,将理性的思维个性的化的表现出来,是一种具有个人艺术特色的视觉传达方式.传达信息的同时有美感.网页设计特点(相对纸媒来说). ...
- jQuery自学笔记(四):jQuery DOM节点操作
获得和设置内容:text( ).html( ) 以及 val( ) text( ) - 设置或返回所选元素的文本内容 html( ) - 设置或返回所选元素的内容(包括 HTML 标记) val( ) ...
- Flask学习记录之Flask-Admin
相信用过Django框架的都不会忘记它强大的Admin功能,Flask-admin是一款能够与Django Admin所媲美的扩展,能够快速创建Web管理界面,实现了用户.文件增删改查等常用功能:也可 ...
- 青蛙的约会(POJ 1061 同余方程)
青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 103802 Accepted: 20198 Descript ...
- iOS开发:自定义tableViewCell处理的问题
还在适配iOS6,索性下一个版本不适配了~~~~~ 问题: *** Assertion failure in -[ PCDiaryDetailReplyCell layoutSublayersOfLa ...