1. $JS中本身只是一个符号而异,在JS里什么也不是。
    但在JS应用库JQUERY的作者将之做为一个自定义函数名了,这个函数是获取指定网页元素的函数,使用非常之频繁,所以好多新手不知道,还以为$JS的什么特殊语法。
    后来,可能有些程序员JQUERY用得多了,发现$这个函数很好用,很方便,所以,在不用JQUERY的情况,一般自己也会自定义一个$函数。
    即:
  1. function $(Nid){
  2. return document.getElementById(Nid);
  3. }
  1. 就这么简单(在JSQUERY里可能稍微功能再强大一点,但主要还是我写的这个功能。)
    以后在网页就不用每次使用document.getElementById("ID名")来获取元素,只用$('ID名')即可,非常简使了。
  1. 三种具体用法:
    1$()可以是$(expresion),即css选择器、Xpathhtml元素,也就是通过上述表达式来匹配目标元素。 
    比如:$("a")构造的这个对象,是用CSS选择器构建了一个jQuery对象——它选择了所有的<a/>这个标签。如: 
    $("a").click(function(){...}) 
    就是在点击页面上的任何一个链接时的触发事件。确切地说,就是jQuery用<a/>这个标签构建了一个对象$("a"),函数 click()是这个jQuery对象的一个(事件)方法。 
  2.  
  3. 比如有这样一段HTML代码: 
  1. <p>one</p>
  2. <div>
  3. <p>two</p>
  4. </div>
  5. <p>three</p>
  6. <a href="#" id="test" onClick="jq()" >jQuery</a>
  1. 而操作这段HTML的是如下一条语句: 
  1. alert($("div>p").html());
  1. $()中的是一个查询表达式,也就是用“div>p”这样一个查询表达式构建了一个jQuery对象,然后的“html()”意思是显示其html内容,也就是上面HTML代码段的[two]。再如: 
    $("<div><p>Hello</p></div>").appendTo("body"); 
    $()中的是一个字符串,用这样一段字串构建了jQuery对象,然后向<body/>中添加这一字串。 
  2.  
  3. 2$()可以是$(element),即一个特定的DOM元素。如常用的DOM对象有documentlocationform等。如这样一行代码: 
    $(document).find("div>p").html()); 
    $()中的document是一个DOM元素,即在全文寻找带<p>的<div>元素,并显示<p>中的内容。 
    3$()可以是$(function),即一个函数,它是$(document).ready()的一个速记方式。如常见的形式是这样的: 
  1. $(document).ready(function(){
  2. alert("Hello world!");
  3. });
  1. 可变形作: 
  1. $(function(){
  2. alert("Hello world!");
  3. });
  1. 对于选择HTML文档中的elementsjQuery有两种方法: 
    1)如$("div>ul a"),它的意思是div标签中的ul标签中的a标签 
    不过,$('div>ul')和$('div ul')是有区别的, 
  2.  
  3. $('div>ul')是<div>的直接后代里找<ul>; 
    $('div ul')是在<div>的所有后代里找<ul>。 
  4.  
  5. 2)用jQuery对象的几个方法(如方法find()、each()等) 
    $("#orderedlist).find("li") 就像 $("#orderedlist li"). each()一样迭代了所有的li,而表达式中的“#”表示HTML中的ID,如上例中的“#orderedlist”就表示“ID为orderedlist所在的标签”。 
  6.  
  7. **************************************************************** 
  8.  
  9. 1、标签选择器$('p')、类选择器$('.myClass')、id选择器$('#myId')相对简单,不多说。不过有一点——$('div>ul')和$('div ul')是有区别的, 
    $('div>ul')是<div>的直接后代里找<ul>;而$('div ul')是在<div>的所有后代里找<ul>。 
    所以,$('#sId>li')所选择的是id"sId"的所有<li>孩子节点,即使这个<li>的后代还有<li>也不是它所找的范围(所找到的DOM对象,只是它本级的DOM对象。)。而$('#sId li:not(.horizontal)'),就是指类名"sId"里面的所有li的子孙中没有horizontal类的所有元素。——这里的not()是一个negation pseudo class. 
    这里返回的是一个jQurey对象,一个数组对象,这个jQuery对象的长度可用.length()得到。 
    2XPath选择器 
    如:选择所有带有title 属性的链接,我们会这样写:$('a[@title]') 
    []里带@,说明[]里的是元素的属性;是个属性选择器 
    []里没@,说明[]里的是元素的子孙。 
    $('ul li')和$('ul[li]')虽然返回的都是一个jQuery数组,但两者的含义正好相反。前者是要找<ul>下所有<li>子孙,而后者却是在找所有子孙为<li>的<ul>数组。 
    XPath中,要找一个“以...开头”的属性,用^=,如找一个name属性是以mail开头的input元素,就用 
    $('input[@name^="mail"]') 
    要找一个“以...结尾”的属性,要用$= 
    要找一个“不头不尾”的属性,用*= 
  10.  
  11. 3、不属于上述的CSSXPath的选择器,就是自定义的选择器了,用“:”表示,这里要用的就是:first,:last,:parent ,:hidden,:visible,:odd,:even,:not('xxx'), ":eq(0)"(始于0),:nth(n),:gt(0),:lt(0),:contains("xxx") 
    如:$('tr:not([th]):even')意为<tr>元素的子孙中不含<th>的所有子孙的偶数项 
  12.  
  13. 4、还有几个,简单不解释了 
    $('th').parent()—— 
    $('td:contains("Henry")').prev()——内容包含有"Henry"的<td>的上一个节点 
    $('td:contains("Henry")').next()——内容包含有"Henry"的<td>的下一个节点 
    $('td:contains("Henry")').siblings()——内容包含有"Henry"的<td>的所有兄弟节点 
    还有一个,就是end(),这个方法肯定是用在某个DOM节点执行了某一动作之后,还想在与其相关的节点上执行类似动作,这里就要用到end()。用过end()方法之后,所返回的是执行动作的那个节点的父节点上。举个例子 
    $(...).parent().find(...).addClass().end() 
    这里执行动作的节点是find(...),是一个数组对象,它所做的动作是“addClass()”,之后,用了个end(),这时所返回的东东就是指向了parent()所指向的节点,也就是执行“addClass()”动作的那个数组对象的父节点。 
  14.  
  15. 5、要直接访问DOM元素,可用get(0)的方法,如 
    $('#myelement').get(0),也可缩写成$('#myelement')[0]

JS中$含义及用法的更多相关文章

  1. JS中$含义和用法

    原博客:https://www.cnblogs.com/jokerjason/p/7404649.html$在JS中本身只是一个符号而异,在JS里什么也不是.但在JS应用库JQUERY的作者将之做为一 ...

  2. JS前端重点 -- Generator 函数的含义与用法

    Generator 函数的含义与用法 1.generator http://www.ruanyifeng.com/blog/2015/04/generator.html http://it.taocm ...

  3. 转: ES6异步编程: co函数库的含义与用法

    转: ES6异步编程: co函数库的含义与用法 co 函数库是著名程序员 TJ Holowaychuk 于2013年6月发布的一个小工具,用于 Generator 函数的自动执行. 比如,有一个 Ge ...

  4. 转: ES6异步编程:Thunk函数的含义与用法

    转: ES6异步编程:Thunk函数的含义与用法 参数的求值策略 Thunk函数早在上个世纪60年代就诞生了. 那时,编程语言刚刚起步,计算机学家还在研究,编译器怎么写比较好.一个争论的焦点是&quo ...

  5. 转: ES6异步编程:Generator 函数的含义与用法

    转: ES6异步编程:Generator 函数的含义与用法 异步编程对 JavaScript 语言太重要.JavaScript 只有一根线程,如果没有异步编程,根本没法用,非卡死不可. 以前,异步编程 ...

  6. [转载]js中return的用法

    一.返回控制与函数结果,语法为:return 表达式; 语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果 二.返回控制,无函数结果,语法为:return;  在大多数情况下,为事件处理函 ...

  7. js中this的用法

    经过近几周的模拟面试题,我查询了一些资料,今天就来说说,在js中this的用法吧.方法有四:第一,用作全局变量,第二,用作表该对象,第三,用作构造函数,第四,用作call和applay

  8. JQuery之append和appendTo的区别,还有js中的appendChild用法

    JQuery之append和appendTo的区别 append()前面是要选择的对象,后面是要在对象内插入的元素内容 appendTo()前面是要插入的元素内容且为Jquery对象,而后面是要选择的 ...

  9. JS中event.keyCode用法及keyCode对…

    js中event.keyCode用法及keyCode对照表 标签: javascriptJavaScriptJavascriptjavaScript 2012-12-11 15:11 HTML Jav ...

随机推荐

  1. [2019杭电多校第一场][hdu6579]Operation(线性基)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6579 题目大意是两个操作,1个是求[l,r]区间子序列的最大异或和,另一个是在最后面添加一个数. 如果 ...

  2. SpringDataJPA使用

    一.简介 SpringDataJpa是 JPA规范的一个很好的实现,简化了开发的复杂度,极大提升了开发的效率.SpringDataJpa通过 Repository接口及子接口可以很方便的实现持久化操作 ...

  3. css炫酷动画收藏

    1.按钮.hover.input动画(cssfx) https://cssfx.dev/ 2.svg 矢量定制icon(ikonate) https://www.ikonate.com/#conten ...

  4. ASE Alpha Sprint - backend scrum 9

    本次scrum于2019.11.14再sky garden进行,持续15分钟. 参与人: Xin Kang, Zhikai Chen, Jia Ning, Hao Wang 请假: Lihao Ran ...

  5. 快速禁止Chrome浏览器缓存

    在前端的开发中,最麻烦的莫过于浏览器的缓存,经常需要清理缓存文件,导致开发效率较低. 但Chrome可以一键禁止浏览器缓存,并且在后续的操作中,无论相同的资源请求多少次,都不会缓存到本地,一起来体验下 ...

  6. 01. Linux-Kali系统网卡配置

    配置网卡操作: vim /etc/network/interfaces auto eth0iface eth0 inet static 配置eth0使用默认的静态地址address 192.168.1 ...

  7. 学Python的第六天

    今天发愤图强,死学Python!!!! 为此小编还买了自己喜欢的McPython! 从小老师就说兴趣是最好的老师,所以呢买这本书是想通过我的世界这款游戏来提高自己的学习兴趣!!! 当然也有私心啦... ...

  8. 发布程序包到Nuget

    今天想着别人都把自己做的程序包发布到nuget上去开放给别人使用,那么我是否也能这么干呢,于是就研究了一番,发现还真可以,而且非常简单,接下来就介绍下发布自己的程序包到nuget上的方法. 一.创建公 ...

  9. rabbitma客户端

    知道答案了,原因是重连的时候,每次重连都创建了一个新的线程,然后有信号的时候,每个线程都连接到rabbitMq服务器上去,导致了同一个IP通过不同端口链接上了服务器,出现了多个channel,而发多次 ...

  10. shell 操作mysql

    1.连接 #!/bin/bash user="root" password="XXXXXX" sql = `mysql -u>/dev/null use ...