原生JS 实现点击按钮创建元素
要求: 点击按钮,随机生成一个20px-100px宽度正方形,随机颜色,随机位置,不能出可视区域外
思路:(1)创建按钮,为按钮添加事件侦听
(2)触发事件,创建一个元素
(3)设置元素样式,包括大小,位置,颜色
基础HTML代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<button>添加</button>
<script> </script>
</body>
</html>
JS代码:
init();
function init() {
var bn = document.getElementById("bn"); //通过id获取按钮bn
bn.addEventListener("click",clickHandler); //为按钮添加点击事件
}
function clickHandler(e) {
var wid = document.documentElement.clientWidth; //获取视口宽度
var hei = document.documentElement.clientHeight; //获取视口高度
var div = document.createElement("div"); //创建一个div
//定义一个局部变量divWidth 存放当前创建的div的大小
var divWidth = Math.floor(Math.random() * 80 + 20);
//设置div的样式,包括 宽 高 定位 背景颜色
div.style.position = "absolute";
div.style.width=divWidth+"px";
div.style.height=divWidth+"px";
//div的位置应该是当前视口宽高减去创建div的宽高 然后取随机值,才能保证div不会超出视口
div.style.left = Math.floor(Math.random() * (wid - divWidth))+"px";
div.style.top = Math.floor(Math.random() * (hei - divWidth))+"px";
div.style.backgroundColor =randomColor();
//将元素添加到body中
document.body.appendChild(div);
}
//定义一个函数,执行返回一个代表颜色的字符串
function randomColor() {
return "#"+Math.floor(Math.random()*0x1000000).toString(16).padStart(6,"0");
}
效果展示:

看完上面的代码,你是不是觉得它看起来有一些 繁杂 也许我们可以将它 “美化” 一下,让代码看起来更漂亮,更加赏心悦目
我们可以将代码中的一些类似的部分摘取出来,用一个函数来完成这些内容,比如为元素添加style 样式
我们可以这么写
// createNewElement 创建一个元素, 函数内有两个参数第一个参数是要创建的元素类型,第二个参数是样式
//通过Object.assign()方法将style内的属性添加给创建的元素的style上
//最后将处理好的元素返回
function createNewElement(elem,style){
var elem=document.createElement(elem);
Object.assign(elem.style,style);
return elem;
}
注: Object.assign(target, source_1, ···)
用于将源对象的所有可枚举属性复制到目标对象中。
我们怎么使用这个函数呢
var elem(用于接收函数return的元素)=createNewElement("div(要创建的元素类型)",{
属性:属性值; //第二个参数为对象,将这个对象传入,并将对象的属性复制到元素的style属性上完成样式的添加.
width:"100px",
backgroundColor:"green"
});
这个函数不仅可以用于这里,还可以用于创建其他元素
init();
function init() {
var bn = document.getElementById("bn"); //通过id获取按钮bn
bn.addEventListener("click",clickHandler); //为按钮添加点击事件
}
function clickHandler(e) {
var wid = document.documentElement.clientWidth; //获取视口宽度
var hei = document.documentElement.clientHeight; //获取视口高度
//定义一个变量divWidth 存放当前创建的div的大小
var divWidth = Math.floor(Math.random() * 80 + 20);
var div=createNewElement("div",{
position : "absolute",
width:divWidth+"px",
height:divWidth+"px",
left: Math.floor(Math.random() * (wid - divWidth))+"px",
top:Math.floor(Math.random() * (hei - divWidth))+"px",
backgroundColor:randomColor()
})
document.body.appendChild(div);
}
// createNewElement 创建一个元素, 函数内有两个参数第一个参数是要创建的元素类型,第二个参数是样式
//通过Object.assign()方法将style内的属性添加给创建的元素的style上
//最后将处理好的元素返回
function createNewElement(elem,style){
var elem=document.createElement(elem);
Object.assign(elem.style,style);
return elem;
}
//定义一个函数,执行返回一个代表颜色的字符串
function randomColor() {
return "#"+Math.floor(Math.random()*0x1000000).toString(16).padStart(6,"0");
}
--
原生JS 实现点击按钮创建元素的更多相关文章
- 原生 js 实现点击按钮复制文本
最近遇到一个需求,需要点击按钮,复制 <p> 标签中的文本到剪切板 之前做过复制输入框的内容,原以为差不多,结果发现根本行不通 尝试了各种办法,最后使了个障眼法,实现了下面的效果 一.原理 ...
- 初探原生js根据json数据动态创建table
初探原生js根据json数据动态创建table 小生以实习生的职位进入了一家非纯软件的公司做asp.net开发,大半个月下来发现公司里居然没有前端工程师,这令我很诧异,跟着公司做项目,发现前端后台没有 ...
- js实现点击按钮时显示弹框,点击按钮及弹框以外的区域时隐藏弹框
转自https://blog.csdn.net/yimawujiang/article/details/86496936 问题:js实现点击按钮时显示弹框,点击按钮及弹框以外的区域时隐藏弹框? 方案一 ...
- win32 htmlayout点击按钮创建新窗口,以及按钮图片样式
最近在做一个C++ win32的桌面图形程序,我不是C++程序员,做这个只是因为最近没什么java的活. windows api,之前接触的时候,还是大学,那时用这个开发打飞机游戏纯粹是娱乐.现在基本 ...
- JS(原生js和jq方式)获取元素属性(自定义属性),删除属性(自定义属性)
JS(原生js和jq方式)获取元素属性(自定义属性),删除属性(自定义属性) 以下内容: 一.获取元素的属性 二.设置元素的属性 三.删除元素的属性 一.获取元素的属性 1-原生JS 获取属性 .ge ...
- 使用原生js 实现点击消失效果
JQ版 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title ...
- js实现点击按钮传值
js实现点击按钮传值 page1源码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8&quo ...
- 原生JS实现点击一个按钮显示一个div,再点击按钮div隐藏,或点击除div外其它空白处div隐藏
<!DOCTYPE html> <html style="font-size: 24px"> <head> <title>js点击按 ...
- js点击按钮为元素随机字体颜色和背景色
文章地址 https://www.cnblogs.com/sandraryan/ 写两个button和一个div,点击按钮分别改变背景色和前景色(字体颜色).产生的是一个随机颜色. <!DOCT ...
随机推荐
- Web开发HTTP协议知识_常用http方法、http状态码等(前端开发和面试必备))
http请求由三部分组成,分别是:请求行.消息报头.请求正文. HTTP(超文本传输协议)是一个基于请求与响应模式的.无状态的.应用层的协议,常基于TCP的连接方式,HTTP1.1版本中给出一种持续连 ...
- 初用MySQL Mysql示例库 Navicat15
初用MySQL Mysql示例库 Navicat15 查询MySQl版本 Mysql shell > select version(); 右括号,not version 查看初始密码 M ...
- 「HAOI2015树上染色」「树形DP」
其实我还不大会树形DP 此题就当练手叭,缕一下思路就好 题目链接 BZOJ4033 题目大意就是给一棵树,对一部分点染成黑色,剩下的为白色,问所有同色点距离之和....... 简明扼要的题意,然额我不 ...
- PE文件格式详解(七)
PE文件格式详解(七) Ox00 前言 前面好几篇在讲输入表,今天要讲的是输出表和地址的是地址重定位.有了前面的基础,其实对于怎么找输出表地址重定位的表已经非常熟悉了. 0x01 输出表结构 ...
- Fetch.ai的突破使急速闪电共识成为现实
Jonathan Ward 区块链的终结问题是由于技术限制,它已经成为区块链技术被广泛采用的障碍.用外行的话来说,终结时间可以看作是事务首次提交到网络并被确认为有效之间的等待时间.为了成功地革新我们的 ...
- Error: error getting chaincode bytes: failed to calculate dependencies报错解决办法
Error: error getting chaincode bytes: failed to calculate dependencies: incomplete package: github.c ...
- MapReduce的运行流程概述
MapReduce处理数据的大致流程 ①InputFormat调用RecordReader,从输入目录的文件中,读取一组数据,封装为keyin-valuein对象 ②将封装好的key-value,交给 ...
- 016.Nginx HTTPS
一 HTTPS概述 1.1 HTTPS介绍 超文本传输安全协议HTTPS(Hypertext Transfer Protocol Secure)是超文本传输协议和SSL/TLS的组合,用以提供加密通讯 ...
- 题解 洛谷 P4492 【[HAOI2018]苹果树】
考虑生成一颗二叉树的过程,加入第一个节点方案数为\(1\),加入第二个节点方案数为\(2\),加入第三个节点方案数为\(3\),发现生成一颗\(n\)个节点的二叉树的方案数为\(n!\). 所以题目中 ...
- Python之threading初探
threading库主要用于基于线程的并行,核心就是Thread类 class threading.Thread(group=None, target=None, name=None, args= ...