JQuery复习基础资料
撰写时间: 2019-09-25 总共: 3292 字 转载请注明: BY-SA 4.0(除特别声明或转载文章外)
JQuery
选择器
类似css的选择器,也是选择一个HTML元素来进行相应的js操作。
// 选择器都以$()来选择。
// 元素选择器
let p = $("p");
// id选择器
let id_dom = $("#id_name");
//class选择器
let class_dom = $(".class_name");
除了以上3个常用的选择器来选择元素外,还提供了包括类似css嵌套选择器一样,可以进行
选择具体有个HTML元素下的某个具体的子元素。
也可以进行所有 元素的选取,包括自身
// 选择所有元素
$("*");
// 选择自身
$(this);
事件处理
获取了元素主要的目的就是对元素进行一定的事件操作了。元素的常用事件也就那几个了。
对标于原生的一些事件的封装。一些常用的JQuery事件:
// 单击事件
$("#one").click(function(){
// 接受一个函数作为相应的click事件操作
});
// 双击事件
$("#two").dblclick(function(){
// 接受一个函数作为相应的dblclick事件操作
});
// 一些鼠标事件,使用方法都差不多
mouseenter(function(){})
mouseleave(function(){})
mousedown(function(){})
mouseup(function(){})
// 悬停事件
hover(
function(){/*进入触发事件*/},
function(){/*离开触发事件*/}
)
// 焦点事件
focus(function(){
// 获得焦点触发的事件
})
blur(function(){
// 失去焦点
})
// 键盘事件
keydown(function(event){
/*
按下一个键
对接受的事件event进行处理
*/
})
keyup(function(event){
/*
松开一个键
对接受的事件event进行处理
*/
})
keypress(data_name,function(event){
/*
按下一个键,并产生一个字符ASCII码返回
接收一个ASCII码数据范围(比如65-90,大写字母)
data_name = {start:65,end:90}
可以通过event.data 获取传入的数据再进行操作
*/
event.which //获取ASCII码
})
使用JQuery实现效果
包括但不限于,隐藏、显示、切换、滑动、一些动画效果等。
一些常用的方法
// 显示隐藏方法
/*
包含指定状态切换的速度也就是显示的速度[slow,fast,毫秒数值]
指定缓动函数:linear/swing
callback是执行完成之后的函数调用
*/
hide(speed,'指定缓动函数',callback);
show(speed,,'指定缓动函数',callback);
// 我们不必单独为一个元素指定显示还是隐藏,
// 可以使用以下函数进行显示和隐藏的切换
toggle(speed,callback)
动画效果简单实现
// 淡入淡出
/*
包含指定状态切换的速度也就是显示的速度[slow,fast,normal,毫秒数值]
callback是执行完成100%之后的函数调用
*/
// 淡入隐藏的元素
fadeIn(speed,callback)
// 淡出可见元素
fadeOut(speed,callback)
// 切换In和Out状态
fadeToggle(speed,callback)
// 渐变为指定的透明度参考css属性[0-1]之间
fadeTo(speed,opacity,callback)
// 滑动效果类似上面
slideDown(speed,callback)
slideUp(speed,callback)
slideToggle(speed,callback)
// 自定义动画效果
// {params}指定一些动画的css属性
// 对位置进程操作需要指定元素的position,脱离原本的静态文档流。
$(selector).animate({params},speed,callback);
// 停止动画
/*stopAll:默认false,清除动画队列
goToEnd:默认false,立即完成当前没完成的动画
*/
stop(stopAll,goToEnd)
动画效果的css属性注意:使用驼峰式来取代css本来的各方向的属性,
比如marginRight 替代 margin-right
JQuery的链式动作
JQuery运行我们可在一个元素上执行多个方法在一条语句上
比如:
$("#id_name").fadeIn().fadeOut()......
进行同一个元素多个方法的执行,避免多次获取元素。
JQuery的DOM操作
包括获取元素内容属性类似原生js的innerHtml等属性。
获取:
// 元素文本内容
text()
// HTML结构
html()
// 表单元素的值
val()
// 获取标签属性
attr()
prop()
关于attr()与prop()的区别:
prop()函数的结果:
1.如果有相应的属性,返回指定属性值。
2.如果没有相应的属性,返回值是空字符串。
attr()函数的结果:
1.如果有相应的属性,返回指定属性值。
2.如果没有相应的属性,返回值是 undefined。
对于HTML元素本身就带有的固有属性,在处理时,使用prop方法。
对于HTML元素我们自己自定义的DOM属性,在处理时,使用 attr 方法。
修改或添加:
现在允许反引号包含一段带参数的字符串可以进行快速的HTML结构的返回。
比如:
let name = "霁";
let html_text = `<strong>我的名字:${name}</strong>`;
// 为id1的元素设置html文本
$("#id1").html(html_text);
// 接受回调函数
$("#id1").html(funtion(i,old_text){
return `Old is ${origText} New is new_text index is:${i}`;
});
以上上替换当前HTML元素内容,
添加新的HTML内容可以使用
// 结尾追加
append()
// 开头追加
prepend()
// 元素之后插入
after()
// 元素之前插入
before()
注意区别:
结尾和开头是针对被选取元素的内容的前后。
比如:
<div>prepend() xxxx append()</div>
before()<div>prepend() xxxx append()</div>after()
删除元素:
// 删除被选择的元素和它的子元素
remove(...)
// 删除子元素
empty(...)
// 都可以指定过滤的元素
// 比如删除指定的class为ul—li的<li>
$(ul).remove(".ul-li");
JQuery的css操作
添加,删除,切换类名
// 添加一个或多个类名
// 类似原生的classList.add()
addClass("...");
// 移除一个或多个类名
removeClass("...");
// 切换类,没有就添加,有就移除
toggleClass("...");
// 设置或者返回css属性
css("属性","要指定的值")
获取元素的高宽属性:
// 列举
// 不包含内外边距和边框
width()
height()
// 包括内边距
innerWidth()
innerHeight()
// 包括 内边距和边框
// 可指定true参数返回包括外边距的宽度
outerWidth()
outerHeight()
引用w3school的例子。
可以看见上述边框为1px,外边距都为3px,内边距都为10px; 内容区域为300px,100px
innerWidth()为:320不包括左右的边框2px
带有true的参数的outerWidth(true) 会返回328px;
结语
上述包括常用的一些JQuery对原生js操作DOM的方法和事件等。是JQuery的基础方法也不为过吧。
剩下的还有什么JQuery的DOM遍历,Ajax的封装,等等一下具体的应用。