js实现模态窗口增加与删除

本文实例为大家分享了js实现模态窗口增加与删除的具体代码,供大家参考,具体内容如下

<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>模态窗口</title> <link rel="stylesheet" href="index.css"> </head> <body> <div id="reset"> <div id="talk">issue<span id="close">&times;</span></div> <div class="group"><label> name </label> <input type="text" id="username"></div> <div class="group"><label> Please enter content <br /></label><textarea id="content"></textarea></div> <input type="submit" value="confirm" id="btn2"> <input type="submit" value="cancel" id="btn3"> </div> <br /> <div id="box"> <a id="btn">Click tweet</a> <ul id="uls"> <li> <a href="javascript:;" class="delete">&times;</a> <h4 class="username">致橡树</h4> <p>我如果爱你——绝不像攀援的凌霄花,借你的高枝炫耀自己;我如果爱你——绝不学痴情的鸟儿,为绿荫重复单调的歌曲;也不止像泉源,常年送来清凉的慰藉;也不止像险峰,增加你的高度,衬托你的威仪。甚至日光。甚至春雨。</p> </li> </ul> </div> <script src="index.js"></script> </body> </html> * { margin: 0; padding: 0; } body{ width:100%; background-image: url(img/1.webp); } ul,li{ list-style: none; } #reset{ display:none; background:#eee; width:500px; height:250px; position:absolute; left:30%; top:35%; } #reset #talk{ width: 100%; height: 35px; background: #ccc; text-align: center; line-height: 35px; font-size: 18px; color: #fff; font-weight: 700; } #talk #close{ position:absolute; right: 5px; top: 0; font-size:20px; width:20px; height:20px; color: #999; cursor:pointer; } #reset .group{ margin: 5px 20px; } #reset .group label{ color: #666; font-size: 14px; } #username { width: 200px; height: 25px; border: 1px solid #eee; outline: none; } #content { width: 460px; height: 110px; border: 1px solid #eee; outline: none; margin-top: 5px; resize: none; } #btn2 { margin-left: 200px; width: 60px; height: 25px; border: 0; border-radius: 5px; background: #ddd; font-size: 14px; color: #666; line-height: 25px; } #btn3 { width: 50px; height: 25px; border: 0; border-radius: 5px; background: #ddd; font-size: 14px; color: #666; padding: 5px; } #box{ margin: 0 auto; width: 1000px; height: auto; background-repeat: no-repeat; background-position: top center; border-radius: 10px; } #box #btn{ display: block; width: 150px; text-align: center; text-decoration: none; color: #00ffba; font-size: 20px; background: #fff; border-radius: 5px; padding: 5px; margin:10px ; cursor: pointer; } #uls{ margin: 20px 10px 0; background: #fff; border-radius: 10px auto 0; } #uls li { padding: 10px 5px; border-bottom: 1px dashed #eee; } #uls li .username { color:#2223218a; padding: 2px 5px; } #uls li p { padding: 10px 10px; color: #aaa; font-size:14px; } #uls li a{ float:right; text-decoration:none; color:#a9a9a9; padding:0px 5px; } window.onload = function () { var box = document.getElementById('box'); var btn = document.getElementById("btn"); var reset = document.getElementById("reset"); var top = document.getElementById("talk"); var close = document.getElementById("close"); var btn2 = document.getElementById("btn2"); var btn3 = document.getElementById("btn3"); btn.onclick=function(){ reset.style.display="block"; }; //关闭弹出页 close.onclick = function(){ reset.style.display="none"; }; btn3.onclick = function(){ reset.style.display = "none"; }; //发布 btn2.onclick = function() { var _username = username.value; var _content = content.value; if (_username == '') { alert('请输入您的姓名'); return; } if (_content == '') { alert('请输入您的留言'); return; } var sensitiveWords = ['共产党', '土匪', '呵呵']; sensitiveWords.forEach(function (v) { while(_content.indexOf(v) !== -1) { _content = _content.replace(v, '***'); } }); // 取消发布 //限制字数为150 function LimitNumber(txt) { var str = txt; str = str.substr(0,150); _content.innerText=str; } if (_content.length>150){ alert("您输入超出限制"); LimitNumber(); } var newLi = document.createElement('li'); newLi.innerHTML = '<a href="javascript:;" class="delete">&times;</a>' + '<div class="username">' + _username + '</div><p>' + _content + '</p>'; uls.appendChild(newLi); username.value = ''; content.value = ''; reset.style.display="none"; }; // 拖拽 reset.onmousedown = function (ev) { var maxLeft = document.documentElement.clientWidth - reset.offsetWidth; var maxTop = document.documentElement.clientHeight - reset.offsetHeight; var e = ev || window.event; var X = e.clientX - reset.offsetLeft; var Y = e.clientY - reset.offsetTop; //只针对IE浏览器 if(reset.setCapture) { reset.setCapture(); } document.onmousemove = function (ev) { var e = ev || window.event; var left = e.clientX - X; var top = e.clientY - Y; //限定范围 if(left < 0){ left = 0; } if(top < 0){ top = 0; } if(top> maxTop ){ top = maxTop; } if(left > maxLeft ){ left = maxLeft; } reset.style.left = left + 'px'; reset.style.top = top + 'px'; }; document.onmouseup = function () { document.onmousemove = null; document.onmouseup = null; //取消捕获事件 if(reset.releaseCapture){ reset.releaseCapture(); } }; }; }; var uls = document.getElementById('uls'); uls.onclick = function (ev) { var e = ev || window.event; var o = e.srcElement || e.target; if(o.nodeName === "A") { uls.removeChild( o.parentNode ); } };

推荐阅读

    js设置div的边框|怎样给div设置边框

    js设置div的边框|怎样给div设置边框,,1. 怎样给div设置边框1、首先新建一个html文件,输入基本的内容,这里设置一个div,并把它的class设置为de

    js设置样式|js设置样式类

    js设置样式|js设置样式类,,js设置样式    javascript改变CSS样式分为局部和全局,分别如下:  一、局部改变样式    有三种方法:直接

    js用代码实现简单购物车

    js用代码实现简单购物车,,图: 选择所有按钮: 复制代码代码如下所示: 选择 笔记本电脑:3000元 笔记本电脑:3000元 笔记本电脑:3000元 笔记本电脑:3

    js设置背景色|js设置颜色

    js设置背景色|js设置颜色,,js设置背景色首先通过js定位到div的子元素,再通过setatteibute方法给属性添加背景色。js设置颜色js改变字体的颜

    Safari调试iOS中的js

    Safari调试iOS中的js,页面,设备,概述对于HTML5的开发,大家都知道Chrome的DevTools工具有强大的功能和友好的用户体验,不仅能快速方便调试Jav

    Bootstrap的js插件之模态框|modal

    Bootstrap的js插件之模态框|modal,模态,饭盒,.modal——指明div元素包裹模态框;.fade——给模态框添加淡入淡出效果;.modal-dialog——包裹

    js默认事件汇总

    js默认事件汇总,事件,表单,默认事件   就是浏览器通过HTML标签或DOM元素提供的一些功能性的默认行为。比如在a标签href属性上的跳转,右键

    js获取元素宽度

    js获取元素宽度,内联,样式,js获取元素宽度1、使用内联样式,即直接把CSS写在HTML元素的style属性中<div > </div>复制代码通过以下js代码

    SQLite使用JSON扩展

    SQLite使用JSON扩展,插件,加载,一、介绍 SQLite3.9.0之后的版本,添加了JSON扩展。在表中可以保存JSON类型。实际上SQLite将JSON类型的

    jscript.dll是什么

    jscript.dll是什么,系统,文件,论坛,显示,扫描,修复,  jscript.dll是Microsoft JavaScript脚本支持相关文件。属于: Microsoft JScript系统 DLL

    postgresql中对jsonb的查询及转换

    postgresql中对jsonb的查询及转换,数据,字段,表数据:需要将strata排除,并且过滤info字段中为{}的数据,将jsonb转换成text,替换“,{,}见SQL:sele