jquery基础学习之样式篇(一)
一.安装与使用
官网下载,然后引入 <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基础学习之样式篇(一)的更多相关文章
- jquery基础学习之动画篇(四)
一,动画效果 hide() show() 隐藏与显示 hide(options) 隐藏 对应display:none,有参数就会变成动画, $(document).click(function () ...
- jquery基础学习之DOM篇(二)
在此之前请牢记,jquery 是一个合集对象!!!! 1.节点创建 js创建方法: 创建元素:document.createElement 设置属性:setAttribute 添加文本:innerHT ...
- jquery基础学习之AJAX篇(五)
理解不深,只知道这么用 jquery 中ajax的请求方法 $.ajax({ url:‘http://...’, //请求网址 type:'GET', //请求方法 success:function( ...
- jquery基础学习之事件篇(三)
一.鼠标事件 click 单击 与 dbclick 双击 用于监听用户的点击操作,在同一元素上同时绑定 click 和 dblclick 事件是不可取的...根据浏览器支持不同一个点击事件是由mous ...
- JQuery基础学习总结
JQuery基础学习总结 简单总结下JQuery: 一:事件 1.change事件 <!DOCTYPE html> <html lang="en"> < ...
- 【总结整理】JQuery基础学习---样式篇
进入官方网站获取最新的版本 http://jquery.com/download/ 中文 https://www.jquery123.com/ <!--JQuery:轻量级的JavaScr ...
- jquery 基础汇总---导图篇
最近在慕课网学习了一些jquery的基础知识,为了方便记忆,整理出来的导图 jQuery基础总共分为4个部分,分别是样式篇.事件篇.动画篇.DOM篇. 样式篇,主要介绍jQuery的基础语法,选择器以 ...
- 【jQuery基础学习】09 jQuery与前端(这章很水)
这章主要是将如何将jQuery应用到网站中,或者说其实就是一些前端知识,对于我这种后端程序来说其实还是蛮有用的. 关于网站结构 文件结构 前端文件分三个文件夹放 images文件夹用来存放将要用到的图 ...
- 【jQuery基础学习】00 序
作为一个从来没有认真学过jQuery的菜来讲,我所学的都是jQuery基础. 算是让自己从0开始系统学一遍吧.学习书籍为:<锋利的jQuery>. 虽然是个序,表示一下我是个菜,但还是来几 ...
随机推荐
- 【XMPP】Smack源码之初步认识
Smack 概述 Smack是一个用于和XMPP服务器通信的类库,由此可以实现即时通讯和聊天. Smack主要优势 非常简单易用,并且有十分强大的 API.只需三行代码就可以向用户发关文本消息: XM ...
- MXNET:多层神经网络
多层感知机(multilayer perceptron,简称MLP)是最基础的深度学习模型. 多层感知机在单层神经网络的基础上引入了一到多个隐藏层(hidden layer).隐藏层位于输入层和输出层 ...
- mysql 5.7 学习
MySQL5.7 添加用户.删除用户与授权 mysql -uroot -proot MySQL5.7 mysql.user表没有password字段改 authentication_string: ...
- java-信息安全(十二)-数字签名【Java证书体系实现】
概述 信息安全基本概念 数字证书 数字证书就是互联网通讯中标志通讯各方身份信息的一串数字,提供了一种在Internet上验证通信实体身份的方式,数字证书不是数字身份证,而是身份认证机构盖在数字身份证上 ...
- 将 GitHub 上的代码向 Coding 更新
问题: 从 GitHub 上 clone 代码到本地很慢,10 KB/s 左右,为了解决这个问题,尝试将 GitHub 上的代码通过离线下载的方式,用百度云和115网盘下载,经常失败,弃之~ 国内也有 ...
- [Bayes] Understanding Bayes: A Look at the Likelihood
From: https://alexanderetz.com/2015/04/15/understanding-bayes-a-look-at-the-likelihood/ Reading note ...
- [Node.js] 06 - Multi-thread and process module
课前阅读:关于Node.js后端架构的一点后知后觉 书推荐:<Node.js design patterns> 衍生问题: 微服务的必要性,Flux架构 容错性和拓展性 一.立体拓展 假设 ...
- webpack + vue 项目 自定义 插件 解决 前端 JS 版本 更新 问题
Webpack 是一个前端资源加载/打包工具.它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源. 它的异步加载原理是,事先将编译好后的静态文件,通过js对象映射,硬编 ...
- 【laravel5.6】 laravel 执行 php artisan route:cache 报错 Unable to prepare route [/] for serialization. Uses Closure.
laravel 在部署的时候.需要优化路由加载,执行命令 php artisan route:cache 报错了.如下 这个异常的错误信息,提示的已经非常明确了:大概意思就是说在闭包里边,是不能够进行 ...
- Excel 函数集(使用过的)
1. SUBTOTAL函数 筛选结果求和 SUBTOTAL(函数编号, 区域) 函数编号 为 1 到 11(包含隐藏值)或 101 到 111(忽略隐藏值)之间的数字,指定使用何种函数在数据清单 ...