jquery mobile 页面间的传递参数
程序员文章站
2022-04-18 14:37:04
...
jq mobile作为一个web开发手机app的框架,打包后的apk,其实就是在手机上模拟一个简易的浏览器,然后进行js操作,在没有服务器端脚本语言的支持下,如何传递参数呢?
很明显,这就要依靠jquery mobile来获取了。
在$(document).bind('pagebeforechange',function(e,data){... ... });事件里面:
- $(document).bind('pagebeforechange',function(e,data){
- if (typeof data.toPage !== "string"){//这个事件会调用两次,但每次的data内容不一样,所以要判断
- return;
- }
- var urlObj = $.mobile.path.parseUrl(data.toPage);//取到一个对象
- var paramStr = urlObj.search;//对象中的参数,格式为 例: ?id=34&key=perfect&action=go
- });
$(document).bind('pagebeforechange',function(e,data){
if (typeof data.toPage !== "string"){//这个事件会调用两次,但每次的data内容不一样,所以要判断
return;
}
var urlObj = $.mobile.path.parseUrl(data.toPage);//取到一个对象
var paramStr = urlObj.search;//对象中的参数,格式为 例: ?id=34&key=perfect&action=go
});
还要处理这个取到的参数,笔者想用诸如serialize,unserialize之类的函数进行处理,可惜都没有找到合适的;于是自己写了个函数来处理:- function getUrlParam(string) {
- var obj = {};
- if (string.indexOf("?") != -1) {
- var string = string.substr(string.indexOf("?") + 1);
- var strs = string.split("&");
- for(var i = 0; i < strs.length; i ++) {
- var tempArr = strs[i].split("=");
- obj[tempArr[0]] = unescape(tempArr[1]);
- }
- }
- return obj;
- }
function getUrlParam(string) {
var obj = {};
if (string.indexOf("?") != -1) {
var string = string.substr(string.indexOf("?") + 1);
var strs = string.split("&");
for(var i = 0; i < strs.length; i ++) {
var tempArr = strs[i].split("=");
obj[tempArr[0]] = unescape(tempArr[1]);
}
}
return obj;
}
于是第一处的代码可以这样处理:
- $(document).bind('pagebeforechange',function(e,data){
- if (typeof data.toPage !== "string"){
- return;
- }
- var paramUrl = $.mobile.path.parseUrl(data.toPage);
- var params = getUrlParam(paramUrl.search);
- });
- function getUrlParam(string) {
- var obj = {};
- if (string.indexOf("?") != -1) {
- var string = string.substr(string.indexOf("?") + 1);
- var strs = string.split("&");
- for(var i = 0; i < strs.length; i ++) {
- var tempArr = strs[i].split("=");
- obj[tempArr[0]] = unescape(tempArr[1]);
- }
- }
- return obj;
- }
转载于:https://blog.51cto.com/yerik/1118129
上一篇: java线程的死锁
下一篇: js不同页面间跳转以及参数传递和调用
推荐阅读
-
jQuery setTimeout传递字符串参数报错的解决方法
-
ASP.Net页面间变量值传递的方法
-
小强的HTML5移动开发之路(47)——jquery mobile基本的页面框架
-
jquery mobile页面跳转后样式丢失js失效的解决方法教程
-
详解react native页面间传递数据的几种方式
-
PHP页面间传递参数实例代码
-
JSP页面中文参数的传递(get和post方法分析)
-
More Effective C++----(12)理解"抛出一个异常"与"传递一个参数"或"调用一个虚函数"间的差异
-
JSP页面间传递参数方法介绍
-
ASP同一站点下gb2312和utf-8页面传递参数乱码的终极解决方法