前几天面试,问的第一个问题就是这个,但是我第一次面试过于紧张,也可能是基础不扎实,特在此重新总结一下该问题的解答。

JavaScript

假设HTML相关代码如下:

<style>
div {
width: 100px;
height: 100px;
border: 1px solid black;
}
</style> <div id="a"></div>
<button id="b">点击变色</button>

那么使用JS事件处理有3种写法:

行内事件

在div标签内加入onclick="document.getElementById('a').style.backgroundColor='pink';"

测试效果如下,符合预期。

如果响应函数在js中定义,则在行中调用时切记要加上(),即<button onclick='btnClick()'></button>

onclick绑定

js代码如下:

var div = document.getElementById('a');
var btn = document.getElementById('b');
btn.onclick = function(){
div.style.backgroundColor = 'pink';
} // 也可以采用下面这种写法
function btnClick(){}
btn.onclick = btnClick;

关于选取元素

要特别注意getElementById参数不需要加#,而且同系列函数常用的还有getElementsByClassgetElementsByTag,除了id选取其他都是得到数组,切记使用时要加下标。

还可以使用querySelector方法,使用如下:

var div = document.querySelector('#a');

与之配套的是querySelectorAll方法,返回数组。

关于改变颜色

  1. 改变颜色也有几种方式,首先是通过给style.property赋值的方式修改,但是属性property要采用小驼峰命名法,如同我们上述所写:
div.style.backgroundColor = 'pink';

这种方式如果要添加多个样式则过于繁琐。

  1. 还可以采用给style.cssText赋值的方式修改(属性名和写css时一样),如下:
div.style.cssText = 'background-color: pink';

但是采用这种方式进行修改,前面的cssText会被后面的覆盖,例:

div.style.cssText = 'background-color: pink';
div.style.cssText = 'border-color: red';

在点击后,显示效果变为:

显然覆盖了前一句背景颜色,但是我们写在style标签中的样式并没有覆盖。

  1. 我们还可以通过获取样式表对象,调取insertRuleaddRule方法来改变样式(首先我们要有一个外部CSS文件,哪怕是空的也行),代码如下
var sheet = document.styleSheets[0];
// insertRule
sheet.insertRule('div{background-color:pink;}'); //addRule
sheet.addRule('div', 'background-color:pink;');

两者的参数稍微有些不同,可以点此查阅。使用这种方式,经测试不会覆盖前面样式。

(但是有点奇怪的是我更改border-color这个属性时,insertRule修改不了,而addRule可以)

addEventListener

上述两种方式属于DOM Level0的事件处理模型,但它们没法在同一个事件上绑定多个事件处理程序,接下来我们使用DOM Level2的事件处理模型来解答。

在一般浏览器上使用addEventListener添加事件,使用removeEventListener移除事件;在IE浏览器中使用attachEventListener添加事件,使用detachEventListener移除事件。

function btnClick() {
div.style.backgroundColor = 'pink';
}
//一般浏览器
div.addEventListener('click', btnClick); //IE浏览器
div.attachEventListener('click', btnClick);

在JS一节中的样式改变方式此处同样适用。

推荐使用此种方式,详情见此

其实可以不需要按钮,直接点击div修改颜色,见这篇博客

jQuery

首先要引入jquery文件:

<script src="./jquery-3.6.0.min.js "></script>

获取元素

var $div = $('#a');
var $btn = $('#b');

有jquery封装,获取元素变得简便许多。

绑定事件

同样有类似JS的三种方式,此处直接一并写了(行内一样,不再赘述):

function btnClick(){}
// click
$btn.click(btnClick); //on
$btn.on('click', btnClick);

其中差距如同JS,on绑定多个事件可以直接在第一个参数字符串中间隔一个空格加上,如:

$btn.on('click mouseover', btnClick);

设置样式

css()

//设置单个属性
$div.css('background-color', 'pink'); //设置多个属性
$div.css({'background-color': 'pink', 'border-color': 'red';})

添加class

//在style标签中设置class
.pink{background-color: pink;} //修改样式
$div.addClass('pink');

Vue

最近正好在学习Vue,索性也写一写。

首先引入vue文件:

<style>
#a{
width: 100px;
height: 100px;
border: 1px solid black;
}
</style> //写好模板
<div id='app'>
<div id='a'></div>
<button>按钮</button>
</div> <script src="./vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {},
methods: {}
})
</script>

v-bind动态绑定样式

在vue实例中定义相关变量和方法:

data:{
color: '';
},
methods:{
btnClick(){
this.color = 'pink';
}
}

在元素中绑定属性和事件:

<div id="app">
<div :style='{backgroundColor: color}'></div>
<button @click='btnClick'>按钮</button>
</div>

还可以直接设置绑定style,为了测试是否会覆盖样式我添加了一个按钮及事件:

data: {
style: {},
},
methods: {
btnClick() {
this.style = {
'background-color': 'pink'
};
},
btnClick2() {
this.style = {
'border-color': 'red'
};
}
} //div
<div :style='style'></div>
<button @click='btnClick'>按钮1</button>
<button @click='btnClick2'>按钮2</button>

点击按钮1:

点击按钮2:

解决办法,将赋值改为添加属性:

btnClick() {
Vue.set(this.style, 'background-color', 'pink');
},
btnClick2() {
Vue.set(this.style, 'border-color', 'red');
}

点击按钮1再点击按钮2后结果为:

如此不会覆盖。

动态绑定class

div元素绑定属性class:

//首先定义样式
<style>
.pink{background-color: pink;}
</style> <div :class='{pink: isPink}'></div>

修改vue实例的data和方法:

data: {
isPink: false,
},
methods: {
btnClick(){
this.isPink = true;
}
}

测试结果:点击后正常显示背景色。

也可以在class属性中动态添加样式class,实现方法有许多,我们就介绍到此。

点击按钮触发div颜色改变的几种写法的更多相关文章

  1. JS---案例:点击按钮设置div背景色渐变

    案例:点击按钮设置div背景色渐变 背景色渐变:设置透明度 <div id="dv"></div> <input type="button& ...

  2. js进阶 12-16 jquery如何实现通过点击按钮和按下组合键两种方式提交留言

    js进阶 12-16 jquery如何实现通过点击按钮和按下组合键两种方式提交留言 一.总结 一句话总结:实现按下组合键提交留言是通过给input加keydown事件,判断按键的键码来实现的. 1.如 ...

  3. React 点击按钮显示div与隐藏div,并给div传children

    最近做了一个react的点击按钮显示与隐藏div的一个小组件: [筛选]组件FilterButton import React,{Component} from 'react'; import {re ...

  4. js构建函数,点击按钮显示div,再点击按钮或其他区域,隐藏div

    这只是一个例子,先看看效果: html代码: <nav> <span class="nav_logo"></span> <h1>云蚂 ...

  5. 定时器应用-点击按钮,div向右移动

    需求是点击button,div就一直往右移动,给个条件left=800px就停止移动,通过定时器来控制. 代码如下: <!DOCTYPE html> <html> <he ...

  6. div最小高度的2种写法

    1.第一种写法: 原理:在IE6中,使用CSS定义div的高度的时候经常遇到这个问题,就是当div的最小高度小于一定的值以后,就会发现,无论你怎么设置最小高度,div的高度会固定在一个值不再发生变动, ...

  7. Android点击事件(click button)的四种写法

    在学习android开发和测试的时候发现不同的人对于click事件的写法是不一样的,上网查了一下,发现有四种写法,于是想比较一下四种方法的不同 第一种方法:匿名内部类 代码: package com. ...

  8. jq 点击按钮显示div,点击页面其他任何地方隐藏div

    css .bl_rencai_32{ float: left; height: 35px; line-height: 35px; } .bl_rencai_32 >input{ width: 3 ...

  9. [JS] 点击按钮触发后台事件前,弹出确认框

    只需要在button中设置onclick属性触发事件即可 下面以ASP.NET代码为例, ASP.NET中按钮客户端触发js代码的属性是OnClientClick <asp:Button ID= ...

  10. 点击按钮后URL呗改变

    这里留个坑,Button默认类型是submit.没有写类型的,可能会导致触发Url改变.要么写类型,要么在按钮对应的Js方法里return.

随机推荐

  1. outlook初用

    以前一直用 Foxmail 收发邮件,由于公司用到 sharepoint 可以跟 outlook 绑定,试了下 outlook. 第一次用 outlook 以为也是跟 foxmail 一样简单配置一下 ...

  2. asp.net core 浏览器向服务端传递对象或对象数组参数服务端接收方式

    日常开发中我们经常会在客户端向服务器端传递参数,下面以asp.net core为例 专门分享传递对象或对象数组方法 一.键值对专递对象 以下是一个表单,现在需求是将以下 表单 所有input元素以独享 ...

  3. Web前端单词大全

    style 修饰width 宽度height 高度title 想说明的text-align 水平对齐方式center 居中 left 居左 right 居右line-height 垂直对齐方式/行高 ...

  4. 串口USART(续二)

    通过前面的分析知道,在LPC824中,USART所拥有的配置寄存器有很多,但在一般情况下,如果只是简单地使用收发功能,则只需要使用到配置寄存器CFG.波特率发生器寄存器BRG.中断使能读取和置位寄存器 ...

  5. 053_Salesforce Lightning与Classic对比

    Classic页面  Lightning页面  特点: 应用程序的切换更加方便 可以快速访问最近项目和备注等 新的记录页面布局 涡轮增压列表视图 仪表板有所变化 圆滑的报告视图 其中最重要的变化也当属 ...

  6. 【PDF】数理科学 2001年01月号 特集:「時間とは何か」- 時間が生んだ世界観とパラダイム -

    书本详情 标题:数理科学 2001年01月号 特集:「時間とは何か」- 時間が生んだ世界観とパラダイム - | 数理科学編集部 | 年份:2001出版社:サイエンス社ISBN10:暂无信息5ISBN1 ...

  7. 使用Wireshark完成实验1

    用来观察协议执行实体之间交换的报文的基本工具被称为分组嗅探器(packet sniffer),一个分组嗅探器被动地拷贝(嗅探)计算机发送和接受的报文,也能显示出这些被捕获报文的各个协议字段的内容.Wi ...

  8. <二>JMeter/Navicat for MYSQL运行案例

    一.JMeter 1. 下载地址:http://jmeter.apache.org/download_jmeter.cgi 2. 选择适合的版本进行下载,如下: 3. 将下载好的压缩包解压到任意文件夹 ...

  9. Linux 使用Squid部署代理缓存服务

    代理缓存服务 Squid是Linux系统中最为流行的一款高性能代理服务软件,通常用作Web网站的前置缓存服务,能够代替用户向网站服务器请求页面数据并进行缓存.简单来说,Squid服务程序会按照收到的用 ...

  10. Jmeter添加while控制器

    通过添加while控制器,可以实现条件+循环判断,使while控制器内的子线程根据之前线程的返回(while控制器内外变量皆可)进行触发+循环的控制. 原理如下:通过Condition判断条件语句是否 ...