项目积累——jQuery

初始化时为文本框赋值,聚焦后清空内容

$(function(){

$("#buyDate").val("格式:2014-01-01");

$("#buyDate").css("color","gray");

$("#buyDate").focus(function(){

if($("#buyDate").val()=="格式:2014-01-01"){

$("#buyDate").val("");

$("#buyDate").css("color","black");

}

});

$("#buyDate").blur(function(){

if($("#buyDate").val()==""||$("#buyDate").val()==null){

$("#buyDate").val("格式:2014-01-01");

$("#buyDate").css("color","gray");

}

});

});

  • 基本选择器

?          元素标签名:$(“a”)选出所有链接元素;

?          #id:通过元素id进行选择,如$(“#form1”)会选择id为form1的元素;

?          .class:通过元素的CSS类来选择,如$(“.boldstyle”)会选择CSS为boldstyle类的元素;

?          以上三种搭配使用:$(“input#name”)会选择id为name的input元素

<script type="text/javascript" src="scripts/jquery-1.3.2-vsdoc2.js"></script>

</head>

<body>

<div id="divMsg">Hello World!</div>

<input id="btnShow" type="button" value="显示" />

<input id="btnHide" type="button" value="隐藏" /><br />

<input id="btnChange" type="button" value="修改内容为 Hello World, too!" />

<script type="text/javascript" >

$("#btnShow").bind("click", function(event) { $("#divMsg").show(); });

$("#btnHide").bind("click", function(event) { $("#divMsg").hide(); });

$("#btnChange").bind("click", function(event) { $("#divMsg").html("Hello World, too!"); });

</script>

(1)       入 “$对象styleId标识”。 示例如下:


3.基本过滤器 Basic Filters 名称


说明


举例


:first


匹配找到的第一个元素


查找表格的第一行:$("tr:first")


:last


匹配找到的最后一个元素


查找表格的最后一行:$("tr:last")


:not(selector)


去除所有与给定选择器匹配的元素


查找所有未选中的 input 元素: $("input:not(:ch


:even


匹配所有索引值为偶数的元素,从 0 开始计数


查找表格的1、3、5...行:$("tr:even")


:odd


匹配所有索引值为奇数的元素,从 0 开始计数


查找表格的2、4、6行:$("tr:odd")


:eq(index)


匹配一个给定索引值的元素注:index从 0 开始计数


查找第二行:$("tr:eq(1)")


:gt(index)


匹配所有大于给定索引值的元素注:index从 0 开始计数


查找第二第三行,即索引值是1和2,也就是比0大


:lt(index)


选择结果集中索引小于 N 的elements 注:index从 0 开始计数


查找第一第二行,即索引值是0和1,也就是比2小


:header


选择所有h1,h2,h3一类的header标签.


给页面内所有标题加上背景色: $(":header").css("#EEE");


:animated


匹配所有正在执行动画效果的元素


只有对不在执行动画效果的元素执行一个动画特效:

$("#run").click(function(){ $("div:not(:animated)").animate({ left: "+});


4. 内容过滤器 Content Filters 名称


说明


举例


:contains(text)


匹配包含给定文本的元素


查找所有包含 "John" 的 div 元素:$("div:contains(‘John‘)")


:empty


匹配所有不包含子元素或者文本的空元素


查找所有不包含子元素或者文本的空元素:$("td:empty")


:has(selector)


匹配含有选择器所匹配的元素的元素


给所有包含 p 元素的 div 元素添加一个 text 类: $("div:has(p)").


:parent


匹配含有子元素或者文本的元素


查找所有含有子元素或者文本的 td 元素:$("td:parent")

$styleId1.value==””&&$styleIdalue==””;


5.可见性过滤器 Visibility
Filters
名称


说明


举例


:hidden


匹配所有的不可见元素

注:在1.3.2版本中, hidden匹配自身或者父类在文档中不占用空间的元素.如果使用CSS visibility属性让其不显示但是占位,则不输入hidden.


查找所有不可见的 tr 元素:$("tr:hidden")


:visible


匹配所有的可见元素


查找所有可见的 tr 元素:$("tr:visible")


6.属性过滤器 Attribute Filters 名称


说明


举例


[attribute]


匹配包含给定属性的元素


查找所有含有 id 属性的 div 元素:
$("div[id]")


[attribute=value]


匹配给定的属性是某个特定值的元素


查找所有 name 属性是 newsletter 的 input 元素: $("input[name=‘newsletter‘]").attr("checked",
true);


[attribute!=value]


匹配给定的属性是不包含某个特定值的元素


查找所有 name 属性不是 newsletter 的 input 元素:
$("input[name!=‘newsletter‘]").attr("checked", true);


[attribute^=value


匹配给定的属性是以某些值开始的元


$("input[name^=‘news‘]")


[attribute$=value]


匹配给定的属性是以某些值结尾的元素


查找所有 name 以 ‘letter‘ 结尾的 input 元素: $("input[name$=‘letter‘]")


[attribute*=value]


匹配给定的属性是以包含某些值的元素


查找所有 name 包含 ‘man‘ 的 input 元素: $("input[name*=‘man‘]")


[attributeFilter1][attributeFilter2][attributeFilterN]


复合属性选择器,需要同时满足多个条件时使用。


找到所有含有 id 属性,并且它的 name 属性是以 man 结尾的: $("input[id][name$=‘man‘]")


7.子元素过滤器 Child Filters 名称


说明


举例


:nth-child(index/even/odd/equation)


匹配其父元素下的第N个子或奇偶元素

‘:eq(index)‘ 只匹配一个元素,而这个将为每一个父元素匹配子元素。:nth-child从1开始的,而:eq()是从0算起的!

可以使用:
nth-child(even) :nth-child(odd) :nth-child(3n) :nth-child(2) :nth-child(3n+1)
:nth-child(3n+2)


在每个 ul 查找第 2 个li: $("ul li:nth-child(2)")


:first-child


匹配第一个子元素

‘:first‘ 只匹配一个元素,而此选择符将为每个父元素匹配一个子元素


在每个 ul 中查找第一个 li: $("ul
li:first-child")


:last-child


匹配最后一个子元素

‘:last‘只匹配一个元素,而此选择符将为每个父元素匹配一个子元素


在每个 ul 中查找最后一个
li:
$("ul li:last-child")


:only-child


如果某个元素是父元素中唯一的子元素,那将会被匹配

如果父元素中含有其他元素,那将不会被匹配。


在 ul 中查找是唯一子元素的
li:
$("ul li:only-child")


8.表单选择器 Forms 名称


说明


解释


:input


匹配所有 input, textarea, select 和button 元素


查找所有的input元素: $(":input")


:text


匹配所有的文本框


查找所有文本框:
$(":text")


:password


匹配所有密码框


查找所有密码框:
$(":password")


:radio


匹配所有单选按钮


查找所有单选按钮


:checkbox


匹配所有复选框


查找所有复选框:
$(":checkbox")


:submit


匹配所有提交按钮


查找所有提交按钮:
$(":submit")


:image


匹配所有图像域


匹配所有图像域:
$(":image")


:reset


匹配所有重置按钮


查找所有重置按钮:
$(":reset")


:button


匹配所有按钮


查找所有按钮:
$(":button")


:file


匹配所有文件域


查找所有文件域:
$(":file")


9.表单过滤器 Form Filters 名称


说明


解释


:enabled


匹配所有可用元素


查找所有可用的input元素: $("input:enabled")


:disabled


匹配所有不可用元素


查找所有不可用的input元素: $("input:disabled")


:checked


匹配所有选中的被选中元素(复选框、单选框等,不包括select中的option)


查找所有选中的复选框元素:
$("input:checked")


:selected


匹配所有选中的option元素


查找所有选中的选项元素: $("select
option:selected")

创建元素--

//使用Dom标准创建元素

var select =
document.createElement("select");

select.options[0] = new Option("加载项1", "value1");

select.options[1] = new Option("加载项2", "value2");

select.size = "2";

var object = testDiv.appendChild(select);

一定不要在页面加载时就改变页面的DOM结构, 比如添加一个元素. 正确的做法是在页面加载完毕后添加或删除元素.

//jQuery
使用动态创建的$(document).ready(function)方法

$(document).ready(

function() { testDiv.innerHTML =
"<div style=\"border:solid 1px #FF0000\">使用动态创建的$(document).ready(function)方法</div>"; }

);

或者使用简便语法:

//jQuery 使用$(function)方法

$(

function() { testDiv.innerHTML +=
"<div style=\"border:solid 1px #FF0000\">使用$(function)方法</div>"; }

);

将JQuery对象转换为DOM对象方法如下:

var $cr=$("#cr");

var cr=$cr[0];

var url = "/cvicdns/cvicdns/htgl/xszzjj.do?operFlag=edit";

showD();

//保存添加的部门

Jquery.post(url,{zzjg_bh:bmbh,zzjg_mc:encodeURIComponent(bmmc)},function(data){

closeD();

if(data=="1") {

alert("保存成功!");

} else {

alert(data);

}

Java文件中:对应encodeURIComponent

if(zzjg_mc != null){

zzjg_mc = java.net.URLDecoder.decode(zzjg_mc, "UTF-8");

}

//通过JQuery获取值、赋文本值、聚焦

if($(‘#email‘).val() == ""){

$(‘#msg‘).html("please enter the email!");

$(‘#email‘).focus;

return false;

}

function ajax_post(){

$.post("action.php",{email:$(‘#email‘).val()},

function(data){

$(‘#msg‘).html(data);

},"text");//这里返回的类型有:json,html,xml,text

//

$("#objFlag_" + len + "_").parent().css("display","none");

<tbody class="line" id="data">//和下面的对应

<script type="text/javascript">

function removeRow(_this){

var objTR=_this.parentNode.parentNode;

var rowh = objTR.rowIndex-1; //点击的链接所在行的行号rowh

var objFlag = $("#objFlag_" + rowh + "_").val();

if(objFlag != "1"){ // 不是新增加的

if(confirm("确定要删除此条记录吗?")){

var zwdhValue = $("#zwdhBefore_" + rowh + "_").val();

var url = "/cvicdns/rlzygl/zdwh/zwzd.do?operFlag=delete";

$.post(url,{zwdh:zwdhValue},function(data){

if(data == "1"){

editableTable.removeRow(rowh);//删除一行

var arrObjFlag = document.getElementsByName("objFlag");

var len = arrObjFlag.length;

alert("删除成功!");

}else if(data == "0"){ // 表示要删除的职务有外键约束,不能删除

alert("删除失败,该职务已经被使用!");

}else{ // 其他异常

alert(data);

}

});

}

}else{ // 删除新增加的

editableTable.removeRow(rowh);//删除一行

var arrObjFlag = document.getElementsByName("objFlag");

var len = arrObjFlag.length;

for(var i = 0; i < len; i++){ // 处理行号

document.getElementById("data").rows[i].cells[0].innerHTML = i + 1;

}

}

}

</script>

//复选框选中

if($("#bgly_qt").attr("checked")=="checked"){

$("#qtly").css("display","");

}

时间: 2024-07-31 05:25:48

项目积累——jQuery的相关文章

项目积累(二)细节问题,提高用户体验

前两天和同事讨论公司系统一个身份证录入文本框,发现还有一个要录入年龄的文本框,都感觉挺麻烦的.其实当录入身份证号后,年龄就是固定的,想到这就动手写jQuery来改进系统,提高用户体验. 首先,身份证从第七位开始时年龄段,如:410223199910210000,这样,就获取身份证的从第七位开始和接下来的八位.在获取当前时间,相减获取年龄.这样 做还是不是准确的,还要考虑月份和具体每天.代码如下: 1 var nowDate = new Date(); 2 var month = nowDate.

项目积累——Blockingqueue,ConcurrentLinkedQueue,Executors

背景 通过做下面一个小的接口系统gate,了解一下mina和java并发包里的东西.A系统为javaweb项目,B为C语言项目,gate是本篇需要完成的系统. 需求 1. A为集群系统,并发较高,会批量发送给gate消息,并且接受gate返回的消息: 2. gate独立部署,将从A接受到的消息压入队列,与B建立连接后,将每条消息验证签名等工作后,发送给B,需要保证性能: 3. B负责处理消息,并返回处理结果,B为gate提供提供六个端口,一个端口可有三个长连接(须由gate发送心跳保持长连接,否

项目积累——Mina

继续上一篇,这篇主要讲通过mina往B端发送消息,并接受消息,mina是一个网络通信框架,封装了javaNIO,简单易用,网上有很多关于他的介绍,在此不赘述了. 如上篇所介绍,完成功能,需要五个类: PoolListener:监听,用来在系统启动的时候创建连接: SessionPool:连接池: SendHandler:处理类: CharsetEncoder:编码: CharsetDecoder:解码: B为我们提供了6个端口,每个端口可建立3个长连接,因此,在系统时,就要创建长连接,下面是一个

项目总结——Jquery LigerUI-表格的使用

LigerUI与EasyUI LigerUI与EasyUI一样,都是一个基于jquery的集成了各种用户界面的框架,包括我们常用的表单.表格等常用的控件,使用它们都可以快速的创建风格统一的界面效果.LigerUI与EasyUI相比,LigerUI的用户量不如EasyUI,所以在使用LigerUI过程中遇到问题,寻找解决方案不像EasyUI那么容易:但是LigerUI它是开源的,当我们遇到问题时可以修改LigerUI的源代码来解决问题. 我实习的项目,开发语言是Java,使用的框架是LigerUI

项目中jquery插件ztree使用记录

最近公司要求做一个关于后台的管理系统.在这个mvvm模式横行的年代,虽然这里用jquery做项目可能有点不符合时代的潮流,但是管他呢,能做出来先在说呗(公司以后要改用angular或者vue来统一前端的制作方式),个人觉得jquery还挺好用的.废话这里就不多叙述了.下面就先来一张完成后的图片展示一下ztree可以完成的功能. 额····这边弹出层的阴影是录制软件的问题(这边的前端插件用的是layui,想用的小伙伴可以自行百度layui,顺便一提,我这里用的版本是layui 1.0的,现在lay

【项目积累】对JSON数据的处理

[项目简述]     接触.NET项目非常长一段时间了,前台用的都是MVC框架.不知道大家是否想过一个问题.我们是怎样将数据显示到前台的,换句话说,MVC能够识别怎么样的数据形式?答案非常easy,就是JSON数据.不太记得的,最好还是找段代码看看.我们须要将数据显示到前台.一定会返回JSON类型的数据. [博客概要] 眼下为止,JSON的应用我们都不陌生了. 但对于JSON的一些理论知识,你真正知道吗?或者说,你在项目调试的时候.以前有在前台alert过一个JSON串吗?有看过JSON串的内容

vue项目引入jQuery

1.打开已经创建好的VUE项目,打开package.json文件,在里面加入这行代码,jquery后面的是版本,根据你自己需求更改. dependencies:{ "jquery":"^2.2.3" } 2. 然后在命令行中cnpm install,大多人应该都是使用的淘宝镜像,所以使用cnpm,如果不是 ,可以使用npm安装. 3.打开项目bulid文件夹下的文件,添加 红色框代码到下图所示位置: 4.打开main.js,在头部引入jQuery文件,具体代码为'

项目积累——js应用

//解决由前台向后台传值中文乱码的问题 encodeURI($("#xmjhbgFile").val())//前台JS中数据加码 String fjmc = java.net.URLDecoder.decode(request .getParameter("fjmc"), "utf-8");//后台解码获取 int i = fjmc.lastIndexOf("\\"); fjmc = fjmc.substring(i + 1)

vue-cli搭建项目引入jquery和jquery-weui步骤详解

vue简介 Vue.js 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用. Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合. 另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动. vue引入jquery 1. 在package.json里加入依赖: dependencies:{ "jquery" : "^3.2.1"}123 2. 然后在集成