一.安装与使用

官网下载,然后引入 <script src="js/jquery-3.3.1.js"></script>,这是生产版本,开发版本替换成min的那个

二.转换

jQuery是一个类数组对象,而DOM对象就是一个单独的DOM元素,

jq转dom转换

console.log( $('div')[0]);//选出来的是dom元素
console.log( $('div').get(0));//选出来的是dom元素

dom转jq
通过$(dom)方法将普通的dom对象加工成jQuery对象之后,我们就可以调用jQuery的方法了
let divs=document.getElementsByTagName('div');
let $div=$(divs);
console.log($div)//jq对象
$div.css('background','pink')

二.选择器们

1.基本选择器

$('#div1') id选择器

$('.div1') 类选择器

$('div') 元素选择器

$('*') 所有选择器

2.层选择器

$('form input') 选择form 下所有的input,包括子孙后代的input

$("#main > *") 选择id为mian 的所有子元素

$(".div1 + input") 选择紧跟着.div1的下一个input,只选一个,如果不紧跟着就没有

$("#prev ~ div") 选择#prev元素下面的所有兄弟div,

$("#prev ~ siblings") 选择#prev元素下面的所有兄弟

3.过滤选择器

$("p:first") 第一个p 元素
$("p:last") 最后一个p 元素
$("p:not(.p1)") 选取所有class不是p1的p元素
:even 奇数行,0开始
:odd 偶数行,0开始
<div class="div6">
<div class="div1">1</div>
<div class="div2">2</div>
<div class="div3">3</div>
<div class="div4">4</div>
<div class="div5">5</div>
</div>
<div class="div8">
<div class="div7"></div>
</div>
eq(index) 选取索引为index的元素,从0开始,$('.div6 div:eq(0)') 第一个div6 下的第一个div,如果有多个符合条件,只选择一个
gt(index) 大于索引的,1开始,gt(0)是第一个元素,即选择大于1的, $('.div6 div:gt(0)') // 2,3,4,5

lt(index) 小于索引的,lt(1) 是第二个元素,$('.div6 div:lt(1)') //1
:header 所有的标签元素

:animated 正在执行的动画
:focus 当前获取焦点的元素

4.内容过滤选择器

:contains(text):选取文件内容包含text的元素 $('.div6 div:contains("1")') //div1 这个有可能选择出多个来
:empty :选取没有子元素或文本内容的元素 $(' div:empty') //div7
:has(selector) : 选取包含选择器的元素 $(' div:has(.div7)') //div8
:parent 选取含有资源是或者文本的元素

5.可见性过滤选择器

:hidden 选取所有不可见的元素 包括display:none,opacity=0,visibility:hidden,input的type=hidden
:visible 选取所有可见的元素

6.属性过滤器

input[name] 选取所有拥有name塑形的input
input[name=xiaofang] 选取所有name=xiaofang的input
input[name!=xiaofang]选取所有name属性的值不是xiaofang的input
input[name^=xiaofang]选取所有name属性的值以xiaofang开头的input
input[name$=xiaofang]选取所有name属性的值以xiaofang结尾的input
input[name|=xiaofang]选取所有name属性以xiaofang为前缀或者就是xiaofang的input
input[name~=xiaofang]选取所有name属性的值以空格隔开包含xiaofang的input
[attribute1][attribute2]..[attributen]用属性选择器合并成一个复合属性选择器,满足多个条件。每选择一次,缩小一次范围。

7.子元素过滤选择器

div:nth-child(index/even/odd/eq(0)) 选取第一个index个div,奇偶位的div,注意中间如果有别的元素,也是占据index数的,但是odd/even只计算div
:last-child ,同上,从最后一个选
:only-child 有独生子的元素

8.表单对象属性过滤选择器

:enable 所有可用的元素
:disable 不可用的元素
:checked 所有被选中的元素
:selected 被选中的option元素

9.表单选择器

:input 基本上所有的表单元素
:text 单文本
:password 密码框
:button 按钮
:radio 单选框
:checkbox 多选框
:submit 提交按钮
:image 图片按钮
:reset 重置按钮
:file 所有的上传域
:hidden 不可见的元素
这一堆都可以用input[type=text/password/button]来替代

三.样式的操作

1.html()
相当于innerHTML

2.text()
返回一个字符串,包含所有匹配元素的合并文本

3.val()

获取input 的值

4.css()
1.两个参数,第一个是属性,第二个是要设置的属性,第二个属性可以是一个回调函数,return出来要传递的值

2.一个参数:获取该属性的值
3.设置值的时候,可以传入一个对象,批量设置
4,获取的时候,可以传入一个数组,最后会返回一个对象

5.addClass()

当一个节点含有多个class,dom元素响应的className属性不是数组,而是含有空格的字符串
addClass(".div1")为每个元素增加.div1,增加多个用数组$('div').addClass(['div1','div2'])
addClass属于追加,不是替换
addClass(function(index,currentClass){}),返回一个或多个用空格隔开的要增加的样式名
.removeClass( [className ] ):每个匹配元素移除的一个或多个用空格隔开的样式名,不填写全部移除
.removeClass( function(index, class)) : 一个函数,返回一个或多个将要被移除的样式名

6.toggleClass()
toggleClass用于解决互斥的切换(比如addClass,removeClass),一次相当于addClass,再一次相当于removeClass

7.attr与property的区别

attr是dom自带的属性,例如id class title align等
property是这个dom元素作为对象,其附加的内容,tabName,nodeName,nodeType,使用prop()方法进行取值或赋值
获取attribute 用attr ,获取property用prop
设置value 为 苹果 $('input:first').attr('value','苹果');,只有一个参数时为获取

//可以根据该元素上的其它属性值返回最终所需的属性值
//例如,我们可以把新的值与现有的值联系在一起:

$('form input:nth-child(3)').attr('value',function(i, val){
return '通过function设置' + val
})

removeAttr() 删除某个属性

jquery基础学习之样式篇(一)的更多相关文章

  1. jquery基础学习之动画篇(四)

    一,动画效果 hide() show() 隐藏与显示 hide(options) 隐藏 对应display:none,有参数就会变成动画, $(document).click(function () ...

  2. jquery基础学习之DOM篇(二)

    在此之前请牢记,jquery 是一个合集对象!!!! 1.节点创建 js创建方法: 创建元素:document.createElement 设置属性:setAttribute 添加文本:innerHT ...

  3. jquery基础学习之AJAX篇(五)

    理解不深,只知道这么用 jquery 中ajax的请求方法 $.ajax({ url:‘http://...’, //请求网址 type:'GET', //请求方法 success:function( ...

  4. jquery基础学习之事件篇(三)

    一.鼠标事件 click 单击 与 dbclick 双击 用于监听用户的点击操作,在同一元素上同时绑定 click 和 dblclick 事件是不可取的...根据浏览器支持不同一个点击事件是由mous ...

  5. JQuery基础学习总结

    JQuery基础学习总结 简单总结下JQuery: 一:事件 1.change事件 <!DOCTYPE html> <html lang="en"> < ...

  6. 【总结整理】JQuery基础学习---样式篇

    进入官方网站获取最新的版本 http://jquery.com/download/    中文 https://www.jquery123.com/ <!--JQuery:轻量级的JavaScr ...

  7. jquery 基础汇总---导图篇

    最近在慕课网学习了一些jquery的基础知识,为了方便记忆,整理出来的导图 jQuery基础总共分为4个部分,分别是样式篇.事件篇.动画篇.DOM篇. 样式篇,主要介绍jQuery的基础语法,选择器以 ...

  8. 【jQuery基础学习】09 jQuery与前端(这章很水)

    这章主要是将如何将jQuery应用到网站中,或者说其实就是一些前端知识,对于我这种后端程序来说其实还是蛮有用的. 关于网站结构 文件结构 前端文件分三个文件夹放 images文件夹用来存放将要用到的图 ...

  9. 【jQuery基础学习】00 序

    作为一个从来没有认真学过jQuery的菜来讲,我所学的都是jQuery基础. 算是让自己从0开始系统学一遍吧.学习书籍为:<锋利的jQuery>. 虽然是个序,表示一下我是个菜,但还是来几 ...

随机推荐

  1. js实现禁止pc端浏览器缩放和获取当前页面浏览器的缩放大小

    众所周知:移动端页面禁止用户缩放界面只需加上<meta name="viewport" content="user-scalable=0">即可,但 ...

  2. Spring Security 之Http Basic认证

    使用Spring Security进行http Basic认证非常简单,直接配置即可使用,如下: <security:http> <security:http-basic>&l ...

  3. Swagger使用小记

    Swagger是一种框架,用于自动生成Restfull API的文档,而不用开发者自己编写文档.它既可以减少我们创建文档的工作量,同时说明内容又整合入实现代码中,让维护文档和修改代码整合为一体,可以让 ...

  4. tensorflow模型量化

    tensorflow模型量化/DATA/share/DeepLearning/code/tensorflow/bazel-bin/tensorflow/tools/graph_transforms/t ...

  5. python中的列表、元组、数组——是不是特别容易混淆啊??

    列表: 1. 即list, 是python内置的数据类型.  它的形式是: a = [1, 2, 3, 4, 5] 2. 列表内的值是可以改变的:  即可以这样子: a[0] = 100,  把列表的 ...

  6. 【代码审计】XIAOCMS_后台database.php页面存在SQL注入漏洞

      0x00 环境准备 XIAOCMS官网: http://www.xiaocms.com/ 网站源码版本:XiaoCms (发布时间:2014-12-29) 程序源码下载:http://www.xi ...

  7. js中的jsonp

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. [原]Jenkins(十三)---jenkins用户权限管理

    * 版权声明:本博客欢迎转发,但请保留原作者信息! http://www.cnblogs.com/horizonli/p/5337874.html 两种策略的比较

  9. 6 CLR静态构造器

    CLR保证一个类型构造器在每个AppDomain中只执行一次,而且这种执行是线程安全的. 作用: 就是初始化静态成员 比如有几个静态成员需要初始化那你把初始化代码放到哪呢? 放到普通构造函数里,那肯定 ...

  10. [转]Java中一周前一个月前时间计算方法

    Java中一周前一个月前时间计算方法 在java语言中,用如下方法获取系统时间: Date date = new Date(); String year=new SimpleDateFormat(&q ...