window.opener.location.reload(); 刷新上一个页面
时间选择框
首先引用js
<script type="text/javascript" src="./js/DatePicker/WdatePicker.js"></script>
input输入框
<input type="text" name="time" id="time" value="" />
<img onclick="WdatePicker({el:'time'})" src="./js/DatePicker/skin/datePicker.gif"
width="16" height="22" align="absmiddle">
多选框的全选和反选
//全选反选
$("input[name='check-box']").not(":checked").attr("checked",true).parent().parent().toggleClass('checkedBox');
$("input[name='check-box']").is(":checked").attr("checked",true).parent().parent().toggleClass('checkedBox'); //多选框的全选反选按钮
var checkflag='false';
function selectAll(){
var field=document.getElementsByName('items');
// 如果全选按钮状态是未选中
if (checkflag == "false"){
for (var i = 0; i < field.length; i++){
field[i].checked = true;
}
// 更改全选按钮选中标志
checkflag = "true";
}else{
for (var i = 0; i < field.length; i++){
field[i].checked = false;
}
// 更改全选按钮选中标志
checkflag = "false";
}
}
取得多选框的value的值
function auditAll(){
var arrVersion = []; //定义一个数组
$('input[name="items"]:checked').each(function(){
arrVersion.push($(this).val());//把选中的区域放入数组
});
alert(arrVersion.join('|')); //把数组转化为字符串进行参数传递
}
动态显示当前时间
function time(){
//获得显示时间的div
t_div = document.getElementById('showtime');
var now=new Date()
//替换div内容
t_div.innerHTML = "现在是"+now.getFullYear()
+"年"+(now.getMonth()+1)+"月"+now.getDate()
+"日"+now.getHours()+"时"+now.getMinutes()
+"分"+now.getSeconds()+"秒";
//等待一秒钟后调用time方法,由于settimeout在time方法内,所以可以无限调用
setTimeout(time,1000);
}
搜索框提示效果,鼠标点击后提示消失
<input name="keyword" type="text" value="请输入关键字" onFocus="if(value==defaultValue){value='';this.style.color='#000'}" onBlur="if(!value){value=defaul tValue;this.style.color='#999'}" style="color:#999999"">
格式化日期为时间戳
/**
* 格式化日期为时间戳
*/
function formatDate(str){
var str=str.replace(/-/g,'/');
var str=new Date(str);
return str.getTime(); }
js的attr往某个html元素中插入值
//id为元素的id,name要插入元素的名称,value此元素的内容
$("#id").attr("name","value");
//demo
$("#filename").attr("title","filename");
jquery获取下拉框的value的值和中间的值
<body>
<select name="PaymentType" style="width:110px" >
<option value="">请选择 </option>
<option value="001">月付</option>
<option value="002">半年付</option>
<option value="003">年付</option>
</select>
<script language="javascript">
//Gettext(obj)结果是月付
function Gettext(obj){
var txt=$(obj).find("option:selected").text();
alert(txt)
}
//Getvalue(obj)结果是001
function Getvalue(obj){
var val=$(obj).find("option:selected").val();
alert(val)
}
</script>
</body>
JS判断undefined类型
if (typeof(reValue) == "undefined") {
alert("undefined");
}
typeof 返回的是字符串,有六种可能:"number"、"string"、"boolean"、"object"、"function"、"undefined"
prompt('',data) 类似alert,输出的内容可以复制
js获取地址栏参数
function GetQueryString(name)
{
var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r!=null)return unescape(r[2]); return null;
}
alert(GetQueryString("参数1"));
alert(GetQueryString("参数2"));
alert(GetQueryString("参数3"));
String
var string = "this is mine"
string.substring(); //截取函数
string.toLowerCase(); //换换小写
string.toUpperCase(); //转换大写
string.indexOf("is") > -1; //字符串检索,检索不到返回-1
string.replace("mine","yours") //字符串替换
string.charCodeAt(2) //返回第二个字符的Unicode编码
string.fromCharCode(60) //返回unicode 为60的字符
encodeURI(string) //将字符串转换成URL编码
decodeURI(code) //同上相反
encodeURIComponent()
decodeURIComponent()
base64Encode()
base64Decode() //base64编码转换
number
var i = 1;
i.toString(); //数字转字符串
i=parseInt(str) //同上相反
typeof i == "number" //判断是否为数字
判断是否为有效的数字
var i = 123; var str = "string";
if( typeof i == "number" ){ } //true //某些方法(如:parseInt,parseFloat)会返回一个特殊的值NaN(Not a Number)
//请注意第2点中的[注意],此方法不完全适合判断一个字符串是否是数字型!!
i = parseInt(str);
if( isNaN(i) ){ }
小数转整数
var f = 1.5;
var i = Math.round(f); //结果:2 (四舍五入)
var i = Math.ceil(f); //结果:2 (返回大于f的最小整数)
var i = Math.floor(f); //结果:1 (返回小于f的最大整数)
格式化显示数字
var i = 3.14159; //格式化为两位小数的浮点数
var str = i.toFixed(2); //结果: "3.14" //格式化为五位数字的浮点数(从左到右五位数字,不够补零)
var str = i.toPrecision(5); //结果: "3.1415"
随机数
//返回0-1之间的任意小数
var rnd = Math.random();
//返回0-n之间的任意整数(不包括n)
var rnd = Math.floor(Math.random() * n)
Math对象
1. Math.abs(num) : 返回num的绝对值
2. Math.acos(num) : 返回num的反余弦值
3. Math.asin(num) : 返回num的反正弦值
4. Math.atan(num) : 返回num的反正切值
5. Math.atan2(y,x) : 返回y除以x的商的反正切值
6. Math.ceil(num) : 返回大于num的最小整数
7. Math.cos(num) : 返回num的余弦值
8. Math.exp(x) : 返回以自然数为底,x次幂的数
9. Math.floor(num) : 返回小于num的最大整数
10.Math.log(num) : 返回num的自然对数
11.Math.max(num1,num2) : 返回num1和num2中较大的一个
12.Math.min(num1,num2) : 返回num1和num2中较小的一个
13.Math.pow(x,y) : 返回x的y次方的值
14.Math.random() : 返回0到1之间的一个随机数
15.Math.round(num) : 返回num四舍五入后的值
16.Math.sin(num) : 返回num的正弦值
17.Math.sqrt(num) : 返回num的平方根
18.Math.tan(num) : 返回num的正切值
19.Math.E : 自然数(2.718281828459045)
20.Math.LN2 : 2的自然对数(0.6931471805599453)
21.Math.LN10 : 10的自然对数(2.302585092994046)
22.Math.LOG2E : log 2 为底的自然数(1.4426950408889634)
23.Math.LOG10E : log 10 为底的自然数(0.4342944819032518)
24.Math.PI : π(3.141592653589793)
25.Math.SQRT1_2 : 1/2的平方根(0.7071067811865476)
26.Math.SQRT2 : 2的平方根(1.4142135623730951)
日期型(Date)
//声明
var myDate = new Date(); //系统当前时间 var myDate = new Date(yyyy, mm, dd, hh, mm, ss);
var myDate = new Date(yyyy, mm, dd);
var myDate = new Date("monthName dd, yyyy hh:mm:ss");
var myDate = new Date("monthName dd, yyyy");
var myDate = new Date(epochMilliseconds);
//获取时间的某部份
var myDate = new Date();
myDate.getYear(); //获取当前年份(2位)
myDate.getFullYear(); //获取完整的年份(4位,1970-????)
myDate.getMonth(); //获取当前月份(0-11,0代表1月)
myDate.getDate(); //获取当前日(1-31)
myDate.getDay(); //获取当前星期X(0-6,0代表星期天)
myDate.getTime(); //获取当前时间(从1970.1.1开始的毫秒数)
myDate.getHours(); //获取当前小时数(0-23)
myDate.getMinutes(); //获取当前分钟数(0-59)
myDate.getSeconds(); //获取当前秒数(0-59)
myDate.getMilliseconds(); //获取当前毫秒数(0-999)
myDate.toLocaleDateString(); //获取当前日期
myDate.toLocaleTimeString(); //获取当前时间
myDate.toLocaleString( ); //获取日期与时间
//计算之前或未来的时间
var myDate = new Date();
myDate.setDate(myDate.getDate() + 10); //当前时间加10天
//类似的方法都基本相同,以set开头,具体参考第2点
//计算两个日期的偏移量
var i = daysBetween(beginDate,endDate); //返回天数
var i = beginDate.getTimezoneOffset(endDate); //返回分钟数
//检查有效日期
//checkDate() 只允许"mm-dd-yyyy"或"mm/dd/yyyy"两种格式的日期
if( checkDate("2006-01-01") ){ } //正则表达式(自己写的检查 yyyy-mm-dd, yy-mm-dd, yyyy/mm/dd, yy/mm/dd 四种)
var r = /^(\d{2}|\d{4})[\/-]\d{1,2}[\/-]\d{1,2}$/;
if( r.test( myString ) ){ }
数组
//声明
var arr = new Array(); //声明一个空数组
var arr = new Array(10); //声明一个10个长度的数组
var arr = new Array("Alice", "Fred", "Jean"); //用值初始化数组
var arr = ["Alice", "Fred", "Jean"]; //用值初始化数组
var arr = [["A","B","C"][1,2,3]]; //声明一个二(多)维数组
//数组与字符串间的转换
var arr = ["A","B","C","D"]; //声明 //数组按分隔符转换成字符串
var str = arr.join("|"); //结果: "A|B|C|D" //字符串切割成数组
arr = str.split("|");
//排序
var arr = [12,15,8,9];
arr.sort(); //结果: 8 9 12 15
//数组随机排序
arr.sort(function(){ return 0.5 - Math.random() });
//组合与分解数组
var arr1 = ["A","B","C","D"];
var arr2 = ["1","2","3","4"]; //奖两个数组组合成一个新的数组
var arr = arr1.concat(arr2); //结果: ["A","B","C","D","1","2","3","4"] //将一个数组切成两个数组(参数1:起始索引,参数2:切割长度)
var arr3 = arr.splice(1,3); //结果: arr3:["B","C","D"] arr["A","1","2","3","4"] //将一个数组切成两个数组,并在原数组补新值
var arr4 = arr.splice(1,3,"AA"); //结果: arr4:["B","C","D"] arr["A","AA","1","2","3","4"]
数组去重
/**
* 去除数组重复元素
*/
function uniqueArray(data){
data = data || [];
var a = {};
for (var i=0; i<data.length; i++) {
var v = data[i];
if (typeof(a[v]) == 'undefined'){
a[v] = 1;
}
};
data.length=0;
for (var i in a){
data[data.length] = i;
}
return data;
}
生成指定范围内的随机数
/**
* 生成制定范围内的随机数
* @param min 第一个参数
* @param max 第二个参数
*/
function random(min,max){
return Math.floor(min+Math.random()*(max-min));
}
延迟函数执行
//延迟函数调用
var tId = setTimeout("myFun()",1000); //延迟1000毫秒后再调用myFun()函数
fucntion myFun(){
//do something
clearTimeout(tId); //销毁对象
}
浏览器特征
1.浏览器名称
//IE : "Microsoft Internet Explorer"
//NS : "Netscape"
var browserName = navigator.appName;
2.浏览器版本
var browserVersion = navigator.appVersion;
3.客户端操作系统
var isWin = ( navigator.userAgent.indexOf("Win") != -1 );
var isMac = ( navigator.userAgent.indexOf("Mac") != -1 );
var isUnix = ( navigator.userAgent.indexOf("X11") != -1 );
4.判断是否支持某对象,方法,属性
//当一个对象,方法,属性未定义时会返回undefined或null等,这些特殊值都是false
if( document.images ){ }
if( document.getElementById ){ }
5.检查浏览器当前语言
if( navigator.userLanguage ){ var l = navigator.userLanguage.toUpperCase(); }
6.检查浏览器是否支持Cookies
if( navigator.cookieEnabled ){ }
使下拉框不可选
$("select[name='select']").attr("disabled",true);
使input框不可编辑 加入readonly属性
<input type="text" value="aa" readonly />
location.href用法
top.location.href=”url” 在顶层页面打开url(跳出框架)
self.location.href=”url” 仅在本页面打开url地址
parent.location.href=”url” 在父窗口打开Url地址
js获取table,克隆table中的tr插入到指定位置
$("#demo tr").length //获取id为demo的table的tr数
$("#demo td").length //获取id为demo的table的td数
$("#third").prevAll().length //获取id为third的tr前面tr的数量
var tr=$("#demo tr").eq(0).clone();//取出id为demo的table的第一个的tr,0表示第一个
tr.appendTo("#demo"); //把克隆的tr插入id为demo的table尾部
tr.children("td").eq(0).html(value);//向tr中的第一个td中插入value,0表示第一个
tr.children("td").eq(1).find("input").attr("num",num);//给tr中的第二个td中的input框里增加num属性并赋值
//点击class为checkbox的多选框时,如果被选中,一些操作
$(".checkbox").click(function(){
if($(this).is(":checked")){
//一些操作
}
})
$("input[name='grades']").not('#10').removeAttr('disabled');//查找inpu框name为grades并且过滤掉id为10的input框 移除disabled属性
$("select[name='select']").attr("disabled",true); //使下拉框不可选
<input type="text" value="aa" readonly /> //使input框不可编辑 加入readonly属性
$('.list_table tr:not(:eq(0))').remove(); //删除table非第一个tr
data为json串,循环data,克隆table为demo的第一个tr,并往tr里插入td,然后把tr插入到class为list_table的表格里
$.each(data,function(i,val){
var tr=$('.demo tr').eq(0).clone(); //克隆table
tr.children("td").eq(0).html(val.school_name);
tr.children("td").eq(1).html(val.school_id);
tr.children("td").eq(2).html(val.manager_name+' '+val.manager_id);
tr.children("td").eq(3).html(val.school_name);
tr.children("td").eq(4).html(val.school_name);
tr.children("td").eq(5).html(val.add_time);
tr.children("td").eq(6).find('input').attr('num',val.id);
tr.appendTo('.list_table');
}
$.each(data,function(i,val){
$("#courseClass").append($("<option>").val(val.id).text(val.classname));
});
首先建立一个通用的表格css 和一个 表格Table:
table
{
border-collapse: collapse;
border-spacing:;
margin-right: auto;
margin-left: auto;
width: 800px;
}
th, td
{
border: 1px solid #b5d6e6;
font-size: 12px;
font-weight: normal;
text-align: center;
vertical-align: middle;
height: 20px;
}
th
{
background-color: Gray;
}
<table>
<tr>
<th style="width: 160px;">表头一</th>
<th style="width: 160px;">表头二 </th>
<th style="width: 160px;">表头三</th>
<th style="width: 160px;">表头四</th>
<th style="width: 160px;">表头五</th>
</tr>
<tr>
<td>第一行第一列</td>
<td>第一行第二列</td>
<td>第一行第三列</td>
<td>第一行第四列</td>
<td>第一行第五列</td>
</tr>
<tr>
<td>第二行第一列</td>
<td>第二行第二列</td>
<td>第二行第三列</td>
<td>第二行第四列</td>
<td>第二行第五列</td>
</tr>
<tr>
<td>第三行第一列</td>
<td>第三行第二列</td>
<td>第三行第三列</td>
<td>第三行第四列</td>
<td>第三行第五列</td>
</tr>
<tr>
<td>第四行第一列</td>
<td>第四行第二列</td>
<td>第四行第三列</td>
<td>第四行第四列</td>
<td>第四行第五列</td>
</tr>
</table>
一、鼠标移动到行更换背景色:
增加一个css样式:
.hover
{
background-color: #cccc00;
}
Js脚本:
$(document).ready(function () {
//鼠标移动到行变色,单独建立css类hover
//tr:gt(0):表示获取大于 tr index 为0 的所有tr,即不包括表头
$("#table1 tr:gt(0)").hover(
function () { $(this).addClass("hover") },
function () { $(this).removeClass("hover") })
});
结果执行结果:
二、 表格奇偶行变色 :
奇数行和偶数行css:
.odd{ background-color: #bbf;}
.even{ background-color:#ffc; }
Js脚本:
$(document).ready(function () {
//奇偶行不同颜色
$("#table2 tbody tr:odd").addClass("odd"),
$("#table2 tbody tr:even").addClass("even")
//或者
//$("#table2 tbody tr:odd").css("background-color", "#bbf"),
//$("#table2 tbody tr:even").css("background-color", "#ffc")
});
结果显示:
三、基本操作:
(1)删除行,比如删除表格中的第二行:
//删除指定行(第二行)
$("#table3 tr:gt(0):eq(1)").remove();
(2)删除列,比如删除表格中的第二列:
//eq:获取子元素索引从 0 开始,先删除表头
$("#table3 tr th:eq(1)").remove();
//nth-child:获取子元素从 1 开始
$("#table3 tr td:nth-child(2)").remove();
(3)删除其它行,比如第二行之外的所有行:
$("#table3 tr:gt(0):not(:eq(1))").remove();
(4)删除其它列,比如第二列之外的所有列:
//先删除表头
$("#table3 tr th:not(:eq(1))").remove();
$("#table3 tr td:not(:nth-child(2))").remove();
(5)隐藏行,比如隐藏第二行:
$("#table3 tr:gt(0):eq(1)").hide();
//或者
//$("#table3 tr:gt(0):eq(1)").css("display", "none")
//显示
//$("#table3 tr:gt(0):eq(1)").css("display", "");
(6)隐藏列,比如隐藏第二列:
$("#table3 tr th:eq(1)").hide();
$("#table3 tr td:nth-child(2)").hide();
//或者
//$("#table3 tr th:eq(1)").css("display", "none");
//$("#table3 tr td:nth-child(2)").css("display", "none");
//显示
//$("#table3 tr th:eq(1)").css("display", "");
//$("#table3 tr td:nth-child(2)").css("display", "");
(7)插入新行,在表格最后的位置:
var newRow = "<tr style=\"background:red;\"><td>新行第一列</td><td>新行第二列</td><td>新行第三列</td><td>新行第四列</td><td>新行第五列</td></tr>";
$("#table3 tr:last").after(newRow);
(8)插入行,在第二行之后插入:
var newRow = "<tr style=\"background:red;\"><td>新行第一列</td><td>新行第二列</td><td>新行第三列</td><td>新行第四列</td><td>新行第五列</td></tr>";
$("#table3 tr:gt(0):eq(1)").after(newRow);
(9)获得单元格的值,比如第二行第三列:
var v = $("#table3 tr:gt(0):eq(1) td:eq(2)").text();
//结果显示:第二行第三列
(10)获取一列的所有值,比如第二列:
var v = "";
$("#table3 tr td:nth-child(2)").each(function () {
v += $(this).text()+" ";
});
//结果:第一行第二列 第二行第二列 第三行第二列
(11)获取一行的所有值,比如第二行:
var v = "";
$("#table3 tr:gt(0):eq(1) td").each(function () {
v += $(this).text() + " ";
});
//结果:第二行第一列 第二行第二列 第二行第三列 第二行第四列 第二行第五列
(12)合并行单元格 比如合并 第二行第二个和第三个单元格:
$("#table3 tr:gt(0):eq(1) td:eq(1)").attr("colspan", 2);
$("#table3 tr:gt(0):eq(1) td:eq(2)").remove();
(13)拆分行单元格将上面合并的单元格还原:
//注意不能使用
//$("#table3 tr:gt(0):eq(1) td:eq(1)").removeAttr("colspan");
$("#table3 tr:gt(0):eq(1) td:eq(1)").attr("colspan", 1);
$("#table3 tr:gt(0):eq(1) td:eq(1)").after("<td>第二行第三列</td>")
(14)合并列单元格,比如合并第二列第二个单元格和第三个单元格
$("#table3 tr:gt(0):eq(1) td:eq(1)").attr("rowspan", 2);
$("#table3 tr:gt(0):eq(2) td:eq(1)").remove();
(15)拆分列单元格,比如将上面刚合并的单元格还原:
$("#table3 tr:gt(0):eq(1) td:eq(1)").attr("rowspan", 1);
//在下面行第一个单元格后插入单元格
$("#table3 tr:gt(0):eq(2) td:eq(0)").after("<td>第三行第二列</td>");
(16)为每个单元格增加点击事件,并弹出该单元格行索引和列索引:
$(document).ready(function () {
//点击#table3 的单元格返回 单元格索引
$("#table3 td").click(function () {
var tdSeq = $(this).parent().find("td").index($(this));
var trSeq = $(this).parent().parent().find("tr").index($(this).parent());
alert("第" + (trSeq) + "行,第" + (tdSeq+1) + "列");
})
});
JS 对输入框进行限制(常用的都有)
1.文本框只能输入数字代码(小数点也不能输入)
<input onkeyup="this.value=this.value.replace(/\D/g,'')" onafterpaste="this.value=this.value.replace(/\D/g,'')">
2.只能输入数字,能输小数点.
<input onkeyup="if(isNaN(value))execCommand('undo')" onafterpaste="if(isNaN(value))execCommand('undo')">
<input name=txt1 onchange="if(/\D/.test(this.value)){alert('只能输入数字');this.value='';}">
3.数字和小数点方法二
<input type=text tvalue="" ovalue="" onkeypress="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;else this.tvalue=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.ovalue=this.value" onkeyup="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;else this.tvalue=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.ovalue=this.value" onblur="if(!this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?|\.\d*?)?$/))this.value=this.o_value;else{if(this.value.match(/^\.\d+$/))this.value=0+this.value;if(this.value.match(/^\.$/))this.value=0;this.ovalue=this.value}">
4.只能输入字母和汉字
<input onkeyup="value=value.replace(/[\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[\d]/g,''))" maxlength=10 name="Numbers">
5.只能输入英文字母和数字,不能输入中文
<input onkeyup="value=value.replace(/[^\w\.\/]/ig,'')">
6.只能输入数字和英文
<input onKeyUp="value=value.replace(/[^\d|chun]/g,'')">
7.小数点后只能有最多两位(数字,中文都可输入),不能输入字母和运算符号:
<input onKeyPress="if((event.keyCode<48 || event.keyCode>57) && event.keyCode!=46 || /\.\d\d$/.test(value))event.returnValue=false">
8.小数点后只能有最多两位(数字,字母,中文都可输入),可以输入运算符号:
<input onkeyup="this.value=this.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')">
//只能输入汉字:
<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))">
//只能输入数字:
<input onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))">
//只能输入英文和数字:
<input onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))">
//控制输入框只能输入文字或数字,也可以不允许输入特殊字符
//这里不允许输入如下字符: (像 !@#$%^&* 等)<br>
<textarea rows=2 cols=20 name=comments onKeypress="if ((event.keyCode > 32 && event.keyCode < 48) || (event.keyCode > 57 && event.keyCode < 65) || (event.keyCode > 90 && event.keyCode < 97)) event.returnValue = false;">
//只禁止空格输入
onkeyup="value=value.replace(/\s/g,'')"
//只能输入中文和英文:
onkeyup="value=value.replace(/[^\a-zA-Z\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\a-zA-Z\u4E00-\u9FA5]/g,''))"
获取文件后缀
function getExt(file_name){
var start=file_name.lastIndexOf(".");
var length=file_name.length;
var result=file_name.substring(start+1,length);
return result;
}
jquery取cookie的方法,需要引用jquery.cookie.js
<script type="text/javascript" src="__PUBLIC__/js/jquery.cookie.js"></script>
var userId=$.cookie('username');
jquery的异步
$.ajaxSetup({async:false});
JS取出对象信息放入数据,get给另外页面处理数据
var fileinfoArray=[];//定义一个数组
$('#filelist input[name="chakan"]').each(function(k,v){
var obj={};//定义一个对象
obj.filename=$(v).attr('filename');//给对象赋值
obj.filestore=$(v).attr('filestore');
obj.num=$(v).attr('num');
obj.defaultpic=$(v).attr('defaultpic');
obj.filetype=$(v).attr('filetype');
fileinfoArray.push(obj);//把对象放入数组
//alert(obj.filename+'|'+obj.defaultpic);
}); //alert(JSON.stringify(fileinfoArray));return false;
//通过JSON.stringify(fileinfoArray)转化为json,发送处理页面
处理页面接收json对象并处理
$resInfo=str_replace('"', '"', $resInfo);//替换引号
//var_dump(json_decode($resInfo,true));//json转化为数组
foreach (json_decode($resInfo,true) as $v){ $Model_t_preselect_files=M('preselect_files','t_','DB_CONFIG');
$data['preselectid']=$id;//保存的资源id
$data['wenjianmingcheng']= $v['filename'];//文件名称
$data['wenjianleixing']=$v['filetype'];//文件类型
$data['shifouhaibao']=$v['defaultpic'];//是否海报
$data['laiyuan']=1;//来源1素材库,2中心库
$data['fid']=$v['num'];//对应素材库的id
$Model_t_preselect_files->add($data); }
jquery radio指定value为选中状态
$('.a[value="女"]').attr("checked","checked");