一个关于JS传参及动态修改页面布局的简单小例子。

效果图:
HTML:
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<link rel="stylesheet" href="css/style.css" rel="external nofollow" />
</head>
<body>
<div id="button"><h1>请为下面的DIV设置样式:</h1><div>点击设置</div></div>
<div id="set">
<div class="set1"><span>请选择背景色:</span><span onclick="cl('red')">红</span><span onclick="cl('yellow')">黄</span><span onclick="cl('blue')">蓝</span></div>
<div class="set2"><span>请选择宽(px):</span><span onclick="wd(200)">200</span><span onclick="wd(300)">300</span><span onclick="wd(400)">400</span></div>
<div class="set2"><span>请选择高(px):</span><span onclick="hd(200)">200</span><span onclick="hd(300)">300</span><span onclick="hd(400)">400</span></div>
<span class="btn" onclick="reset()">恢复</span>
<span class="btn" onclick="apply()">确定</span>
</div>
<div id="box"></div>
<script type="text/javascript" src="js/js.js"></script>
</body>
</html>
CSS:
/*top:26%; left:40%;*/
#box{width:100px; height: 100px; border:4px black solid;margin-top:100px;}
#button div{background: red; width:100px; height:40px; float:left; color:white; text-align: center; line-height: 40px; cursor: pointer;}
#set{width:20%; height:28%; border:15px rgb(156,148,156) solid; background:white; position: absolute; top:300px; left:300px; box-shadow: 0 0 8px gray; display:none;}
#set div{height: 40px; margin: 20px auto;}
#set div span{width:45px; height:40px; display:block; float:left; margin-left:10px; color:white; line-height:40px; text-align:center; cursor:pointer;}
#set div span:hover{border:1px black solid}
#set div span:nth-of-type(1){width:auto; color:black; font:18px/40px "微软雅黑"; margin-left:12%; border:none; cursor:auto;} /*:nth-of-type()表示同级同容器下该种类型的第几个标签括号内的数字即指第几个,从1开始*/
#set .set1 span:nth-of-type(2){background:rgb(230,46,0); margin-left:5px;}
#set .set1 span:nth-of-type(2):hover{background:red}
#set .set1 span:nth-of-type(3){background:rgb(239,189,0)}
#set .set1 span:nth-of-type(3):hover{background:yellow}
#set .set1 span:nth-of-type(4){background:rgb(90,148,239)}
#set .set1 span:nth-of-type(4):hover{background:blue}
#set .set2 span{border:1px rgb(198,198,198) solid; color:rgb(136,140,143)}
#set .set2 span:nth-of-type(1):hover{background:white;}
#set .set2 span:nth-of-type(2){background:rgb(239,239,239); margin-left:5px;}
#set .set2 span:nth-of-type(3){background:rgb(239,239,239)}
#set .set2 span:nth-of-type(4){background:rgb(239,239,239)}
#set .set2 span:hover{background:rgb(239,148,0)}
#set .btn{width:60px; height:30px; background:#002952; color:white; display:block; float:left; margin-left:10px; margin-top:10px; text-align:center; line-height:30px; cursor:pointer;}
#set span:nth-of-type(1){margin-left:32%;}
JS:
onload = function(){ //加载完毕给div添加点击事件,可以不这么做,像下面的reset / apply一样建立一个函数并在该div上写上Onclick点击事件调用函数即可
var btn = document.getElementById('button').getElementsByTagName('div');
btn[0].onclick = function(){
document.getElementById('set').style.display = 'block';
}
}
var box = document.getElementById('box'); //建立全局变量获取DIV对象
function wd(x){ //改变宽度
box.style.width = x + 'px';
}
function hd(x){ //改变高度
box.style.height = x + 'px';
}
function cl(x){ //改变颜色
box.style.background = x;
}
function apply(){
document.getElementById('set').style.display = 'none';
}
function reset(){ //恢复DIV原来的布局
box.style.width = 100 + 'px';
box.style.height = 100 + 'px';
box.style.background = 'white';
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js传参
# js动态布局
# js给onclick事件赋值
# 动态传参数实例解说
# url 编码 js url传参中文乱码解决方案
# 用js通过url传参把数据从一个页面传到另一个页面
# 给js文件传参数(详解)
# js设置function参数默认值(适合没有传参情况)
# 纯js实现瀑布流布局及ajax动态新增数据
# 请选择
# 几个
# 并在
# 微软
# 这么做
# 写上
# 背景色
# 括号内
# 该种
# 加载
# 全局变量
# 一个函数
# yellow
# red
# cl
# onclick
# DIV
# button
# span
# set
相关文章:
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
网站制作报价单模板图片,小松挖机官方网站报价?
如何在万网ECS上快速搭建专属网站?
建站主机CVM配置优化、SEO策略与性能提升指南
宝塔面板创建网站无法访问?如何快速排查修复?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
子杰智能建站系统|零代码开发与AI生成SEO优化指南
常州自助建站:操作简便模板丰富,企业个人快速搭建网站
如何选择建站程序?包含哪些必备功能与类型?
如何制作网站标识牌,动态网站如何制作(教程)?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
建站之星如何开启自定义404页面避免用户流失?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
网站制作难吗安全吗,做一个网站需要多久时间?
如何在Ubuntu系统下快速搭建WordPress个人网站?
nginx修改上传文件大小限制的方法
攀枝花网站建设,攀枝花营业执照网上怎么年审?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
广平建站公司哪家专业可靠?如何选择?
建站主机功能解析:服务器选择与快速搭建指南
如何选择香港主机高效搭建外贸独立站?
b2c电商网站制作流程,b2c水平综合的电商平台?
建站之星备案流程有哪些注意事项?
如何在IIS中新建站点并配置端口与IP地址?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
如何获取上海专业网站定制建站电话?
如何通过FTP服务器快速搭建网站?
html制作网站的步骤有哪些,iapp如何添加网页?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
平台云上自助建站如何快速打造专业网站?
如何在阿里云高效完成企业建站全流程?
西安专业网站制作公司有哪些,陕西省建行官方网站?
如何在阿里云ECS服务器部署织梦CMS网站?
制作宣传网站的软件,小红书可以宣传网站吗?
建站ABC备案流程中有哪些关键注意事项?
建站之星收费标准详解:套餐费用及年费价格表一览
如何在云主机快速搭建网站站点?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
Android自定义控件实现温度旋转按钮效果
如何配置支付宝与微信支付功能?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
香港服务器租用每月最低只需15元?
西安大型网站制作公司,西安招聘网站最好的是哪个?
网站微信制作软件,如何制作微信链接?
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
网站制作价目表怎么做,珍爱网婚介费用多少?
视频网站制作教程,怎么样制作优酷网的小视频?
七夕网站制作视频,七夕大促活动怎么报名?
如何通过可视化优化提升建站效果?
北京制作网站的公司,北京铁路集团官方网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。