jq相关操作
1事件:
<div class="ele">123</div>
box.onclick = function(ev){
ev:系统传入的事件对象
ele.innerText;
}
鼠标事件=>clientX,clientY
键盘事件=>ctrlkey,keyCode
鼠标事件:
onmouse enter|move|down|up|leave
onclick|dblclick oncontextmenu
键盘事件:onkeydown|up
定时器:
setInterval|setTimeout
setInterval(fn,1000)
clearInterval|clearTimeout
jq
jQuery是一个高效,精简并且功能丰富的javascript工具库
$是jQuery的别名
<script src = "jquery-3.3.1.js"></script>
<script>
//注意,一定在引入jQuery之后,再使用jQuery提供各种操作
选择器
①获取满足条件的所有页面元素jq对象
$("css3选择器语法");
②拿到指定索引的页面元素jq对象
$("css3选择器语法").eq(index);
③拿到指定索引的页面元素js对象(jq数组放的都是js对象)
$("css3选择器语法")[index];
$("css3选择器语法").get(index);
④js对象转jq对象
$(js对象)
文档加载
问题:
在标签建立前的jq语法中使用该标签
解决方法:
让jq语法在页面加载后再执行
文档加载方法
1.js
window.onload = function(){
}
2.jq
$(document).ready(function(){});
简写:$(function(){});
onload结构和资源都加载完毕
只能绑定一个事件方法
ready 结构加载完毕
可以绑定多个事件方法
页面加载的方法
1.可以保证页面结构一定加载完毕
2.可以保证数据的局部化(不会被外界直接读写)
注:导入jq一定要在使用jq之前
<script src="js/jquery-3.3.1.js">
</script>
<script>
$(function(){
$(".top").css("background-color","cyan");}
);
</script>
jq操作元素对象
<script>
// <!--更改文本-->
// 链式操作:几乎每一个方法都具有返回值(元素对象)
// $(".top li:first-child").text("哈哈").html("<strong>鲨鱼</strong>");
<!--更改样式-->
// $(".top").css("width",function () {
// width要加双引号,this是js对象,$(this)将js对象转换为jq对象
// 可以使用height(),括号不能丢,语句后的分号不能丢
// return $(this).height()*2;
// });
// $(".top").height("400px").css("background-color","cyan");
// $(".top li").css({
// 属性后的值要加双引号
// color:"yellow",
// fontSize:"14px",
// float:"left"
// });
// console.log($(".top"));
// console.log($)
// console.log(jQuery)
</script>
// 修改类名
// $(".top").addClass("bot");
// console.log($(".top").addClass().removeClass("bot"))
// 增加全局属性
// $("img").attr("src","http://onehdwallpaper.com/wp-content/uploads/2015/11/Most-Beautiful-Girl-in-Flowers-Field.jpg");
// 删除全局属性
// $("img").removeAttr("src");
// 获取全局属性
// console.log($("img").attr("xzh"));
jq获取盒子信息
显示信息
#盒子信息:
#宽高(content)|内边距(padding)|边框(border)|外边距(margin)
.top {
margin: 5px;
padding: 10px;
border: 20px solid green;
width:200px;
height: 300px;
background-color: orange;
list-style: none;
}
// var res = $(".top").css("padding");
// console.log(res);//10px 带单位
// var res = $(".top").width();
// console.log(res);//width就是content的宽 200不带单位
// var res = $(".top").innerWidth(); // 220 innerWidth w要大写,等于width加上padding宽
// console.log(res);
// var res = $(".top").outerWidth();//260 outerWidth 等于width 加上 padding 加上 border宽
// console.log(res);
// var res = $(".top").outerWidth(true);//270 加上true的话,还要再加上margin宽,
// console.log(res);
位置信息
.nav{
width: 100px;
height: 100px;
background-color: red;
position: absolute;
top:20px;
left:20px;
margin: 10px 10px;
}
//相对窗口偏移:算margin产生的距离
$(function () {
var res = $(".nav").offset();//{top: 30, left: 30}//相对于窗口的偏移,要算margin的值
console.log(res);
});
//绝对定位偏移(top,left):不算margin产生的距离
$(function () {
var res = $(".nav").position();//{top: 20, left: 20}不算margin的值
console.log(res);
})
position().top
offset().top
jq操作元素对象
<!--更改文本-->
// 链式操作:几乎每一个方法都具有返回值(元素对象)
// $(".top li:first-child").text("哈哈").html("<strong>鲨鱼</strong>");
<!--更改样式-->
// $(".top").css("width",function () {
// width要加双引号,this是js对象,$(this)将js对象转换为jq对象
// 可以使用height(),括号不能丢,语句后的分号不能丢
// return $(this).height()*2;
// });
// $(".top").height("400px").css("background-color","cyan");
// $(".top li").css({
// 属性后的值要加双引号
// color:"yellow",
// fontSize:"14px",
// float:"left"
// });
事件
$(".box").on("click",function(){
alert($(this).text())
})
var d = "AAA"
#四个参数,第一个事件,第二个指派,第三个参数,第四个功能,
$(".box").on("click","span",{aaa:d},function(ev)){
console.log(ev);
console.log(ev.data.aaa);#参数保存在data属性中
console.log(ev.clientX);
}
!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="js/jquery-3.3.1.js"></script>
</head>
<body>
<div class="box">
<span>"哈哈"</span>
<a >"呵呵"</a>
</div>
</body>
<script>
var b = "aaa";
$(".box").on("click","a",{a:b},function (ev) {
console.log(ev.clientX);
console.log(ev.data.a);
})
</script>
</html>
取消默认事件;
<style>
div{
width: 100px;
height: 100px;
background-color: red;
}
</style>
</head>
<body>
<div></div>
</body>
<script src="jquery-3.3.1.min.js"></script>
<script>
$("div").on("contextmenu",function (ev) {
ev.preventDefault()//第二种方法
var bg = $(this).css("background-color");
alert(bg);
// return false;第一种方法
})
父子都有点击方法时,取消父级方法
$(".sup,.sub").on("click",function (ev) {
ev.stopPropagation();//阻止事件的传播,冒泡
var cname = this.className;
alert(cname);
})
jq相关操作的更多相关文章
- JS、JQ相关小技巧积攒
JS.JQ相关小技巧积攒,以备不时之需. 1.js 获取时间差:时间戳相减.new Date().getTime() 获得毫秒数,除以(1000*60*60*24) 获得天数. 2.重定向操作:页面 ...
- 从零自学Hadoop(20):HBase数据模型相关操作上
阅读目录 序 介绍 命名空间 表 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...
- 从零自学Hadoop(21):HBase数据模型相关操作下
阅读目录 序 变量 数据模型操作 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...
- 理解CSV文件以及ABAP中的相关操作
在很多ABAP开发中,我们使用CSV文件,有时候,关于CSV文件本身的一些问题使人迷惑.它仅仅是一种被逗号分割的文本文档吗? 让我们先来看看接下来可能要处理的几个相关组件的词汇的语义. Separat ...
- Liunx下的有关于tomcat的相关操作 && Liunx 常用指令
先记录以下liunx下的有关于tomcat的相关操作 查看tomcat进程: ps-ef|grep java (回车) 停止tomcat进程: kill -9 PID (进程号如77447) (回车) ...
- pip的相关操作
>Python中的pip是什么?能够做些什么? pip是Python中的一个进行包管理的东西,能够下载包.安装包.卸载包......一些列操作 >怎么查看pip的相关信息 在控制台输入: ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- php对二维数组进行相关操作(排序、转换、去空白等)
php对二维数组进行相关操作(排序.转换.去空白等) 投稿:lijiao 字体:[增加 减小] 类型:转载 时间:2015-11-04 这篇文章主要介绍了php对二维数组进行相关操作,包括php对 ...
- SQL语言和DML相关操作以及相应的运算符
SQL 1.结构化查询语言 2.特点 a.第四代编程语言,更接近自然语言 b必须有数据库系统解释执行 c.对象名,关键字不区分大小写 d.字符串必须要用单引号引起来,不能用双引号 e.每条语句最后用分 ...
随机推荐
- JS创建函数的方法
方法一:函数声明. function foo(){ } 方法二:函数表达式. var foo=function(){ } 另外还有一种自执行函数表达式.主要用于创建一个新的作用域,在此作用域内声明的变 ...
- C# 特性之事件
事件的本质---特殊的多路广播委托 定义事件: 事件访问修饰符一般为public 定义为公共类型可以使事件对其他类可见 事件定义中还包括委托类型,既可以是自定义委托类型也可以是EventHandler ...
- Java中的list与Set、Map区别及适用场景
Collection接口是集合类的根接口,Java中没有提供这个接口的直接的实现类,但是却让其被继承产生了两个接口,就是Set和List.Set中不能包含重复的元素.List是一个有序的集合,可以包含 ...
- 云服务中IaaS、PaaS、SaaS的区别
越来越多的软件,开始采用云服务. 云服务只是一个统称,可以分成三大类. IaaS:基础设施服务,Infrastructure-as-a-service PaaS:平台服务,Platform-as-a- ...
- Java常用函数式接口--Consumer接口使用案例
第一种方式: 第二种方式:
- FusionCharts3.2.1 参数的详细说明和功能特性
功能特性animation 是否动画显示数据,默认为1(True)showNames 是否显示横向坐标轴(x轴)标签名称rotat ...
- python深浅拷贝问题
Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 又叫变量对对象的引用 l ...
- POJ 3133 Manhattan Wiring (插头DP,轮廓线,经典)
题意:给一个n*m的矩阵,每个格子中有1个数,可能是0或2或3,出现2的格子数为2个,出现3的格子数为2个,要求将两个2相连,两个3相连,求不交叉的最短路(起终点只算0.5长,其他算1). 思路: 这 ...
- COGS 696. [IOI1996][USACO 2.3] 最长前缀
★ 输入文件:prefix.in 输出文件:prefix.out 简单对比时间限制:1 s 内存限制:128 MB 描述 USACO 2.3.1 IOI96 在生物学中,一些生物的结构 ...
- 快速WCF
初级原理:通得过地址调用接口服务,接口服务调用对应实现方法 援引文章地址:http://www.cnblogs.com/iamlilinfeng/archive/2012/09/25/2700049. ...