JavaScript基础回顾知识点记录6-操作元素样式和事件对象(介绍基本使用)
- js 中 操作元素样式
- 通过js修改元素内联样式(设置和读取的都是内联样式)
- 获取当前元素显示的样式
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<style type="text/css">
#box1 {
width: 200px;
height: 200px;
background-color: aquamarine;
}
</style>
<body>
<button type="button" id="btn1">点我下1</button>
<button type="button" id="btn2">点我下2</button>
<button type="button" id="btn3">点我下3</button>
<br><br>
<div id="box1"> </div>
</body>
<script type="text/javascript">
window.onload = function() {
var btn01 = document.getElementById("btn1");
var box01 = document.getElementById("box1");
btn01.onclick = function() {
/*
通过js修改元素内联样式:
语法: 元素对象.style.样式名 = 样式值
样式名: background-color 是不符合的, 需要改为驼峰命名: backgroundColor
注意: 这种方法设置和读取的都是内联样式
*/
box01.style.width = "400px";
box01.style.height = "400px";
box01.style.backgroundColor = "red";
}
/*
获取当前元素显示的样式:
语法: 元素对象.currentStyle.样式名 。 此方法只有IE浏览器支持
其他浏览器获取样式: getComputedStyle(元素对象,null).样式名 ; */
var btn2 = document.getElementById("btn2");
btn2.onclick = function() {
alert(box01.currentStyle.width);
} var btn3 = document.getElementById("btn3");
btn3.onclick = function() {
var style_obj = getComputedStyle(box1, null);
alert(style_obj.width);
}
}
</script>
</html>
- js 中 事件对象
- 当事件的响应函数被触发时,浏览器每次都会将一个事件对象作为实参传递进响应函数
- 在这个事件对象中封装了当前事件相关的一切信息(鼠标的坐标、键盘那个键被按下,鼠标滚动的方向等)
- 注意: 在ie8及以下浏览器中,响应函数触发时,不会传递事件对象。 事件对象是作为window对象的属性来存储的。
- 以一个鼠标移入某个区域后显示x、y坐标为例子
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<style type="text/css">
#areaDiv {
width: 200px;
height: 100px;
border: black 3px solid;
margin-bottom: 10px;
} #showMsg {
width: 200px;
height: 30px;
border: black 3px solid;
}
</style>
<body>
<div id="areaDiv"></div>
<div id="showMsg"></div>
</body>
<script type="text/javascript">
var areaDiv = document.getElementById('areaDiv');
var showMsg = document.getElementById('showMsg'); /*
onmousemove 事件: 鼠标在元素中移动时触发
事件对象: 当事件的响应函数被触发时,浏览器每次都会将一个事件对象作为实参传递进响应函数
在这个事件对象中封装了当前事件相关的一切信息(鼠标的坐标、键盘那个键被按下,鼠标滚动的方向等)
note: 在ie8及以下浏览器中,响应函数触发时,不会传递事件对象。 事件对象是作为window对象的属性来存储的。 */ areaDiv.onmousemove = function(e) {
// 解决事件对象兼容性问题: 两种写法:
// if (!e) {
// e = window.e;
// }
e = e || window.e;
showMsg.innerHTML = 'x坐标:' + e.clientX + ',y坐标:' + e.clientY;
} areaDiv.onmouseout = function() {
showMsg.innerHTML = '';
}
</script>
</html>
- 鼠标移动事件,实现某个div跟随鼠标移动(复制代码运行直接看效果更直观)
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<style type="text/css">
#box {
position: absolute;
width: 50px;
height: 50px;
background-color: #7FFFD4;
}
</style>
<body style="height: 1200px;">
<div id="box"> </div>
</body>
<script type="text/javascript">
/*
clientX 和 clientY 是获取当前可见页窗口的坐标
pageX 和 pageY 是获取相对当前页面的坐标 (当页面可以往下滚动时,需要使用这个获取坐标),但是在IE8中不支持
*/
document.onmousemove = function(e) {
/*
获取滚动条高度
IE和火狐不识别滚动条属于body的, 谷歌、edge可以识别。
IE和火狐认为滚动条属于html的。documentElement,但是edge识别不了html的滚动条
*/
var st = document.body.scrollTop || document.documentElement.scrollTop;
e = e || window.e;
var box = document.getElementById('box');
box.style.left = e.clientX + 'px';
box.style.top = e.clientY + st + 'px';
}
</script>
</html>
JavaScript基础回顾知识点记录6-操作元素样式和事件对象(介绍基本使用)的更多相关文章
- JavaScript基础回顾知识点记录4-正则表达式篇(介绍基本使用)
js 中 正则表达式使用 创建正则对象和test方法使用 /* 创建正则表达式的对象 语法: var 变量 = new RegExp("正则表达式","匹配模式" ...
- JavaScript基础回顾知识点记录3
js 中 垃圾回收 //将不在使用的对象设置为null , js就会自动进行垃圾回收机制 var obj = {}; obj = null; js 中 数组基本介绍 数组也是一个对象 与普通对象功能类 ...
- JavaScript基础回顾知识点记录2
js 使用嵌套for循环输出三角形 for(var i=0; i<5; i++){ //正三角 // for(var j=0; j<i+1; j++){ // document.write ...
- JavaScript基础回顾知识点记录1
js执行顺序为从上往下执行 js中有6种数据类型 基本数据类型为: String Number Boolean Null Undefined 引用数据类型为: Object 使用typeof 查看对象 ...
- Javascript基础回顾 之(三) 面向对象
本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...
- Javascript基础回顾 之(一) 类型
本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...
- Javascript基础回顾 之(二) 作用域
本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...
- JavaScript 基础回顾——对象
JavaScript是基于对象的解释性语言,全部数据都是对象.在 JavaScript 中并没有 class 的概念,但是可以通过对象和类的模拟来实现面向对象编程. 1.对象 在JavaScript中 ...
- javascript基础入门知识点整理
学习目标: - 掌握编程的基本思维 - 掌握编程的基本语法 typora-copy-images-to: media JavaScript基础 HTML和CSS 京东 课前娱乐 众人皆笑我疯癫,我笑尔 ...
随机推荐
- 前端5jQuery
内容概要 jQuery简介 查找标签 jQuery操作标签 jQuery事件操作 jQuery动画效果(了解) 前端第三方框架(基础) 内容详情 jQuery简介
- 利用Github Action实现Tornadofx/JavaFx打包
原文地址: 利用Github Action实现Tornadofx/JavaFx打包 - Stars-One的杂货小窝 最近开了个新项目,主要是个工具软件,也算个人的自娱自乐吧,也算开源的一部分,想着都 ...
- ExtJS 布局-Anchor 布局(Anchor layout)
更新记录: 2022年5月30日 发布本篇 1.说明 anchor布局类似auto布局从上到下进行堆叠,但不同的是其可以指定每个元素相对于容器大小的比例. 当调整父容器大小,容器根据指定的规则调整所有 ...
- php7.1 安装amqp扩展
在php开发中使用rabbitmq消息队列时,需要安装PHP扩展amqp,安装步骤如下: 直接使用pecl进行amqp扩展的安装, /usr/local/php/bin/pecl install am ...
- C++ 炼气期之变量的生命周期和作用域
1. 前言 什么是变量的生命周期? 从变量被分配空间到空间被收回的这一个时间段,称为变量的生命周期. 什么是变量的作用域? 在变量的生命周期内,其存储的数据并不是在任何地方都能使用,变量能使用的范围, ...
- VMware 安装 Anolis OS
安装时参考的以下文章 VMware Workstation Pro 虚拟机安装 VMware Workstation Pro 安装 龙蜥操作系统(Anolis OS) Anolis OS 8 安装指南 ...
- SAP Html viewer
1 *&---------------------------------------------------------------------* 2 *& Report RSDEM ...
- python小题目练习(八)
题目:电视剧的收视率排行榜 需求:实现如下图所示需求 代码展示: """Author:mllContent:电视剧的收视率排行榜Date:2020-11-16" ...
- 再测云原生数据库性能:PolarDB依旧最强,TDSQL-C、GaussDB变化不大
1.摘要 近期,腾讯云数据库在文章「腾讯云TDSQL-C重磅升级,性能全面领跑云原生数据库市场」中提到,某些场景下性能有非常大的提升,且超过国内某橙色云厂商.恰好,在5月份,我们对各个厂商的云原生数据 ...
- exe4j下载和使用
https://blog.csdn.net/weixin_44678104/article/details/101015065