本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处。  

    http://www.cnblogs.com/king-xg/p/6382603.html

  通过jquery来手机页面隐藏域或含有name属性的input标签值,生成XML字符串传送到服务器,可通过dom4j的xml解析技术进行参数获取

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<script type="text/javascript" src="js/jquery-1.8.2.js" ></script>
<title>页面参数收集插件</title>
<script type="text/javascript"> function clickBT(){
var str = collect();
$("#text").text(str);
} function collect(){
var head = '<?xml version="1.0" encoding="UTF-8"?>';
var root = $("<root></root>");
var arr = $(document).find(":input[type='hidden'][path],:text[path],:hidden[path],:password[path],input[path],span[path],textarea[path],select[path]");
var xml = "";
for(var i = ; i < arr.length; i ++){
if(i+ >= arr.length){
xml = splitArr($(arr[i]),root);
break;
}
splitArr($(arr[i]),root);
}
return (head+"<root>"+xml+"</root>"); } function splitArr(obj,root){
var path = obj.attr('path').toLowerCase();
// 拆分path
var paths = path.split("/");
var reg = /\[[A-Za-z0-]+\]/;
var pnode = root;
for(var i = ; i < paths.length;i ++){
if(reg.test(paths[i])){
var tagName = paths[i].substring(,paths[i].indexOf('['));
var index_str = paths[i].substring(paths[i].indexOf('[')+,paths[i].indexOf(']'))
var index = parseInt(index_str);
// 存在[],多层次节点
// 判断是否存在该索引的节点
if(pnode.children(tagName).length < index+){
// 不存在该标签
var node = $("<"+tagName+">"+"</"+tagName+">");
pnode.append(node);
pnode = node;
}else{
// 存在该标签
pnode = pnode.children(tagName).eq(index);
}
}else{
// 不存在[]
// 判断是否存在该标签
if(pnode.children(paths[i]).length==){
pnode = pnode.children(paths[i]).eq();
}else{
// 打印错误
if(pnode.children(paths[i]).length>){
throw new Error("标签:"+paths[i]+"--存在多层次节点");
return null;
}
var node = $("<"+paths[i]+">"+"</"+paths[i]+">");
pnode.append(node);
// 初始化pnode
pnode = node;
}
}
}
//pnode.text("<![CDATA["+obj.val()+"]]>");
pnode.text(obj.val());
return root.html();
} </script>
</head>
<body>
<input type="hidden" path="project/persons/person[0]/name" value="king"/>
<input type="hidden" path="project/persons/person[0]/age" value=""/> <input type="hidden" path="project/persons/person[1]/name" value="arise"/>
<input type="hidden" path="project/persons/person[1]/age" value=""/> <input path="project/base_info/project_name" value="功能性项目"/>
<input path="project/base_info/create_time" value="2017-02-07"/> <input type="text" path="project/base_info/money" value="" />
<input type="text" value="xxx" /> <textarea path="project/base_info/msg">king</textarea> <select id="sele" path="second_message/sec_msg">
<option></option>
<option></option>
<option></option>
<option></option>
</select> <span path="message/text">it is only text!</span> <input path="project/books/book[0]/menu/section[0]" value="章节0"/>
<input path="project/books/book[0]/menu/section[1]" value="章节1"/>
<input path="project/books/book[1]/menu/section[0]" value="</section>"/>
<input path="project/books/book[1]/menu/section[1]" value="章节1"/>
<input path="project/books/book[2]/menu/section[0]" value="章/r/n节0"/>
<input path="project/books/book[2]/menu/section[1]"/>
<input path="project/books/book[2]/menu/section[2]" value="章节2"/>
<input type="button" name="collection" value="collect" onclick="javascript:clickBT()" /> <textarea id="text" style="width: 500px;height: 400px;"></textarea>
</body>
</html>

若有不足之处,还望指出!
                   

jquery收集页面参数生成xml,用于与server做数据交互的更多相关文章

  1. QtQuick多页面切换、多页面切换动画、多个qml文件数据交互

    一.QtQuick多页面切换方法 (1)“隐藏法” 前一个视图visible设为false或者透明度opacity设为0,相当于“隐藏”了,实际还存在: 要显示的视图visible设为true或者透明 ...

  2. 利用Java.util.UUID来生成唯一ID(用来做数据库主键好用)

    UUID(Universally Unique Identifier)全局唯一标识符,是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的.按照开放软件基金会(OSF)制定的标准计算, ...

  3. 【转】以XML文件方式保存用户数据——2013-08-25 22

    正在做项目中有很多游戏数据要保存,常见的玩家数据这些比较简单的可以用CCUserDefault.它是cocos2d-x用来存取基本数据类型用的.保存为XML文件格式. 主要方法:(和java的map很 ...

  4. MUI框架-10-MUI 数据交互-跳转详情页面

    MUI框架-10-MUI 数据交互-跳转详情页面 上一篇介绍了如何实现数据交互,给别人的 API 发送 ajax 请求,我们得到数据,再使用 art-template 模板引擎拼接 HTML,最终实现 ...

  5. Ajax--PHP+JQuery+Ajax解析json、XML数据、加载页面

    一.JQuery+Ajax用get.post方式提交和请求数据 知识要点: $('#userName').blur(function () { var txt = $(this).val(); $.a ...

  6. jQuery ajax() 参数,回调函数,数据类型,发送数据到服务器,高级选项

    $.ajax({ options:/*类型:Object;  可选.AJAX 请求设置.所有选项都是可选的.*/ async:/*类型:Boolean; 默认值: true.默认设置下,所有请求均为异 ...

  7. jquery 实现页面局部刷新ajax做法

    这个方法就多了去了,常见的有以下几种:下面介绍全页面刷新方法:有时候可能会用到 window.location.reload()刷新当前页面. parent.location.reload()刷新父亲 ...

  8. 大数据技术之_25_手机APP信息统计系统项目_01_APP 数据生成模块 + 数据收集模块 + 数据处理模块框架搭建 + 业务需求处理 + 数据展示模块 +项目总结 + 问题总结

    一 项目概述1.1 角色1.2 业务术语1.3 项目效果展示二 项目需求三 项目概要3.1 项目技术架构3.2 项目目录结构3.3 项目技术选型3.4 项目整体集群规划3.5 创建项目工程四 APP ...

  9. java 解析并生成 XML

    在 java 中使用 Dom4j 解析 XML 对 XML 文件的解析,通常使用的是 Dom4j 和 jdom 作为XML解析工具. 在此只介绍下 Dom4j 对 XML 文件的解析使用方法. 1. ...

随机推荐

  1. Table Tennis Game 2(找规律)

    Description Misha and Vanya have played several table tennis sets. Each set consists of several serv ...

  2. PSP Daily——团队项目Alpha发布

    视频展示:优酷视频链接.文案如下 PSP Daily软件NABCD分析: 1) N (Need 需求) PSP Daily 解决了用户(软件工程课上学生)记录例行报告.写每周PSP表格和统计的需求.潜 ...

  3. 20162328蔡文琛 Bag类

    在刚刚开始着手这个作业时,想的是使用for循环来自己写出add等方法来,但是在看过API后知道了Arraylist这个java已有的列表类,于是就只用ArrayList的方法很快的就做了出来.在进行B ...

  4. Alpha冲刺——第七天

    Alpha第七天 听说 031502543 周龙荣(队长) 031502615 李家鹏 031502632 伍晨薇 031502637 张柽 031502639 郑秦 1.前言 任务分配是VV.ZQ. ...

  5. lintcode395-硬币排成线 II

    395-硬币排成线 II 有 n 个不同价值的硬币排成一条线.两个参赛者轮流从左边依次拿走 1 或 2 个硬币,直到没有硬币为止.计算两个人分别拿到的硬币总价值,价值高的人获胜. 请判定 第一个玩家 ...

  6. lintcode-206-区间求和 I

    206-区间求和 I 给定一个整数数组(下标由 0 到 n-1,其中 n 表示数组的规模),以及一个查询列表.每一个查询列表有两个整数 [start, end] . 对于每个查询,计算出数组中从下标 ...

  7. gridview 第一行编辑

    <%@ Page Language="C#" AutoEventWireup="true" Codebehind="Default.aspx.c ...

  8. codepen & js demos

    codepen & js demos Mutation Observer & customize resize event listener & demo https://co ...

  9. 【JQuery】使用JQuery 合并两个 json 对象

    一,保存object1和2合并后产生新对象,若2中有与1相同的key,默认2将会覆盖1的值 1 var object = $.extend({}, object1, object2); 二,将2的值合 ...

  10. 【Python】Python网络编程

    python内置封装了很多常见的网络协议的库,因此python成为了一个强大的网络编程工具,这里是对python的网络方面编程的一个简单描述. urllib 和 urllib2模块 urllib 和u ...