• 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-操作元素样式和事件对象(介绍基本使用)的更多相关文章

  1. JavaScript基础回顾知识点记录4-正则表达式篇(介绍基本使用)

    js 中 正则表达式使用 创建正则对象和test方法使用 /* 创建正则表达式的对象 语法: var 变量 = new RegExp("正则表达式","匹配模式" ...

  2. JavaScript基础回顾知识点记录3

    js 中 垃圾回收 //将不在使用的对象设置为null , js就会自动进行垃圾回收机制 var obj = {}; obj = null; js 中 数组基本介绍 数组也是一个对象 与普通对象功能类 ...

  3. JavaScript基础回顾知识点记录2

    js 使用嵌套for循环输出三角形 for(var i=0; i<5; i++){ //正三角 // for(var j=0; j<i+1; j++){ // document.write ...

  4. JavaScript基础回顾知识点记录1

    js执行顺序为从上往下执行 js中有6种数据类型 基本数据类型为: String Number Boolean Null Undefined 引用数据类型为: Object 使用typeof 查看对象 ...

  5. Javascript基础回顾 之(三) 面向对象

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  6. Javascript基础回顾 之(一) 类型

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  7. Javascript基础回顾 之(二) 作用域

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  8. JavaScript 基础回顾——对象

    JavaScript是基于对象的解释性语言,全部数据都是对象.在 JavaScript 中并没有 class 的概念,但是可以通过对象和类的模拟来实现面向对象编程. 1.对象 在JavaScript中 ...

  9. javascript基础入门知识点整理

    学习目标: - 掌握编程的基本思维 - 掌握编程的基本语法 typora-copy-images-to: media JavaScript基础 HTML和CSS 京东 课前娱乐 众人皆笑我疯癫,我笑尔 ...

随机推荐

  1. vue项目经常遇到的Error: Loading chunk * failed

    vue项目随着代码量.业务组件.路由页面等的丰富,出于性能要求考虑不得不使用代码分割技术实现路由和组件的懒加载,这看似没什么问题 当每次通过npm run build构建生产包并部署到服务器后,操作页 ...

  2. SQL的语法

    SQL的语法 SQL通用语法 SQL语句可以单行或多行书写,以分号(";")结尾. SQL语句可以使用空格或缩进增强可读性. MySQL数据库的SQL语句不区分大小写(建议关键字大 ...

  3. Linux/Ubuntu 安装Redis

    更新记录 2022年6月15日 发布. 2022年6月12日 开始编写. 安装Redis 更新源 sudo apt update 安装redis sudo apt install redis-serv ...

  4. Redis 中的事务分析,Redis 中的事务可以满足ACID属性吗?

    Redis 中的事务 什么是事务 1.原子性(Atomicity) 2.一致性(Consistency) 3.隔离性(Isolation) 4.持久性(Durability) 分析下 Redis 中的 ...

  5. JDBC、ORM、JPA、Spring Data JPA,傻傻分不清楚?一文带你厘清个中曲直,给你个选择SpringDataJPA的理由!

    序言 Spring Data JPA作为Spring Data中对于关系型数据库支持的一种框架技术,属于ORM的一种,通过得当的使用,可以大大简化开发过程中对于数据操作的复杂度. 本文档隶属于< ...

  6. React.js中JSX的原理与关键实现

    在开始开发之前,我们需要创建一个空项目文件夹.安装 初始化 npm init -y 2.安装webpack相关依赖 npm install webpack webpack-cli -D 安装babel ...

  7. linux目录结构及定时任务

    1. Linux的根目录(最顶层的目录) windows系统有根目录:c盘的根目录就是c:\ d盘的根目录就是d:\ 每个盘(分区)都有自己的根目录 Linux系统, 也支持多个分区 Linux的分区 ...

  8. JS中通过id或者class获取文本内容

    一.JS通过id获取文本内容 二.JS通过class获取文本内容

  9. Pytorch从0开始实现YOLO V3指南 part5——设计输入和输出的流程

    本节翻译自:https://blog.paperspace.com/how-to-implement-a-yolo-v3-object-detector-from-scratch-in-pytorch ...

  10. CentOS6安装使用ntp同步时间

    [root@server yum.repos.d]# yum install ntp已加载插件:fastestmirror, priorities, refresh-packagekit, secur ...