JS传参及动态修改页面布局


Posted in Javascript onApril 13, 2017

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

效果图:

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';
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
游戏人文件夹程序 ver 4.03
Jul 14 Javascript
怎么判断js脚本加载完成
Feb 28 Javascript
利用原生JavaScript获取元素样式只是获取而已
Oct 08 Javascript
js实现选中页面文字将其分享到新浪微博
Nov 05 Javascript
JS正则匹配URL网址的方法(可匹配www,http开头的一切网址)
Jan 06 Javascript
TypeScript入门-基本数据类型
Mar 28 Javascript
详解VUE 数组更新
Dec 16 Javascript
React Native之prop-types进行属性确认详解
Dec 19 Javascript
详解Webpack-dev-server的proxy用法
Sep 08 Javascript
详解在vue-cli3.0中自定css、js和图片的打包路径
Aug 26 Javascript
微信小程序如何实现点击图片放大功能
Jan 21 Javascript
Vue中登录验证成功后保存token,并每次请求携带并验证token操作
Sep 08 Javascript
从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例
Apr 13 #Javascript
MUI 解决动态列表页图片懒加载再次加载不成功的bug问题
Apr 13 #Javascript
MUI  Scroll插件的使用详解
Apr 13 #Javascript
MUI 上拉刷新/下拉加载功能实例代码
Apr 13 #Javascript
从零开始学习Node.js系列教程四:多页面实现的数学运算示例
Apr 13 #Javascript
mui上拉加载功能实例详解
Apr 13 #Javascript
从零开始学习Node.js系列教程三:图片上传和显示方法示例
Apr 13 #Javascript
You might like
oracle资料库函式库
2006/10/09 PHP
PHP测试程序运行时间的类
2012/02/05 PHP
php文件打包 下载之使用PHP自带的ZipArchive压缩文件并下载打包好的文件
2012/06/13 PHP
php实现的网络相册图片防盗链完美破解方法
2015/07/01 PHP
php实现生成验证码实例分享
2016/04/10 PHP
PHP chr()函数讲解
2019/02/11 PHP
把JS与CSS写在同一个文件里的书写方法
2007/06/02 Javascript
jquery pagination插件实现无刷新分页代码
2009/10/13 Javascript
复制Input内容的js代码_支持所有浏览器,修正了Firefox3.5以上的问题
2010/06/21 Javascript
JQuery中$.ajax()方法参数详解及应用
2013/12/12 Javascript
基于javascript实现彩票随机数生成(简单版)
2020/04/17 Javascript
浅析Javascript的自动分号插入(ASI)机制
2016/09/29 Javascript
jQuery实现隔行变色的方法分析(对比原生JS)
2016/11/18 Javascript
ReactJs设置css样式的方法
2017/06/08 Javascript
vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法
2018/01/25 Javascript
详解vue的diff算法原理
2018/05/20 Javascript
基于Vue-cli快速搭建项目的完整步骤
2018/11/03 Javascript
在vue项目实现一个ctrl+f的搜索功能
2020/02/28 Javascript
[39:18]完美世界DOTA2联赛PWL S3 Forest vs LBZS 第二场 12.17
2020/12/19 DOTA
python2.7删除文件夹和删除文件代码实例
2013/12/18 Python
Python中字符串对齐方法介绍
2015/05/21 Python
Python中执行存储过程及获取存储过程返回值的方法
2017/10/07 Python
python join方法使用详解
2019/07/30 Python
python中用logging实现日志滚动和过期日志删除功能
2019/08/20 Python
python框架flask入门之环境搭建及开启调试
2020/06/07 Python
HTML+CSS3+JS 实现的下拉菜单
2020/11/25 HTML / CSS
食堂个人先进事迹
2014/01/22 职场文书
活动总结模板
2014/05/09 职场文书
股东授权委托书范本
2014/09/13 职场文书
2014党员四风对照检查材料思想汇报
2014/09/17 职场文书
甜品店创业计划书
2014/09/21 职场文书
政府班子四风问题整改措施思想汇报
2014/10/08 职场文书
2014年学前班工作总结
2014/12/08 职场文书
2015年全国爱眼日活动方案
2015/05/05 职场文书
2019假期福利管理制度!
2019/07/15 职场文书
springboot利用redis、Redisson处理并发问题的操作
2021/06/18 Java/Android