js原生弹出框

前段时间研究了下bootstarp框架,对于那个模态框非常感兴趣,于是查资料自己写了一个弹出框,总的来说兼容性不太好,但是总之来说做出来了,css并没有怎么修饰,所以可能出来的效果比较难看,但是毕竟这个demo已经成型,若想好看的话就自己在css修饰一下就好。

<html>
	<head>
		<meta charset="utf-8">
	</head>
			<script>
				/*
				 * 弹出DIV层
				*/
				function showDiv()
				{
					var Idiv     = document.getElementById("Idiv");
					var mou_head = document.getElementById('mou_head');
					Idiv.style.display = "block";
					//以下部分要将弹出层居中显示
					Idiv.style.left=(document.documentElement.clientWidth-Idiv.clientWidth)/2+document.documentElement.scrollLeft+"px";
					Idiv.style.top =(document.documentElement.clientHeight-Idiv.clientHeight)/2+document.documentElement.scrollTop-50+"px";
					 
					//以下部分使整个页面至灰不可点击
					var procbg = document.createElement("div"); //首先创建一个div
					procbg.setAttribute("id","mybg"); //定义该div的id
					procbg.style.background = "#000000";
					procbg.style.width = "100%";
					procbg.style.height = "100%";
					procbg.style.position = "fixed";
					procbg.style.top = "0";
					procbg.style.left = "0";
					procbg.style.zIndex = "500";
					procbg.style.opacity = "0.6";
					procbg.style.filter = "Alpha(opacity=70)";
					//背景层加入页面
					document.body.appendChild(procbg);
					document.body.style.overflow = "hidden"; //取消滚动条
					 
					//以下部分实现弹出层的拖拽效果
					var posX;
					var posY;
					mou_head.οnmοusedοwn=function(e)
					{
						if(!e) e = window.event; //IE
						posX = e.clientX - parseInt(Idiv.style.left);
						posY = e.clientY - parseInt(Idiv.style.top);
						document.onmousemove = mousemove;
					}
					document.onmouseup = function()
					{
						document.onmousemove = null;
					}
					function mousemove(ev)
					{
						if(ev==null) ev = window.event;//IE
						Idiv.style.left = (ev.clientX - posX) + "px";
						Idiv.style.top = (ev.clientY - posY) + "px";
					}
				}
				function closeDiv() //关闭弹出层
				{
					var Idiv=document.getElementById("Idiv");
					Idiv.style.display="none";
					document.body.style.overflow = "auto"; //恢复页面滚动条
					var body = document.getElementsByTagName("body");
					var mybg = document.getElementById("mybg");
					body[0].removeChild(mybg);
				}
			</script>
	<body>
		<div id="Idiv" style="display:none; position:absolute; z-index:1000; background:#67a3d9; width:300px;height:200px;">
			<div id="mou_head" style="width="100px; height=10px;z-index:1001; position:absolute;">这个是用来实现拖层</div>
			<input type="button" value="关闭" οnclick="closeDiv();" />
		</div>
		<input type="button" value="点击" οnclick="showDiv()">
<!--结束-->
	</body>
</html>



Vue 3 是一款流行的 JavaScript 架,用于构建用户界面和单页面应用程序。手写原生弹出可以通过 Vue 3 的组件来实现,以下是一个简单的示例: 1. 新建一个名为 "MyAlert" 的 Vue 组件,该组件包含一个 "message" 属性和一个方法 "closeAlert"。 ``` <template> <div class="my-alert" v-show="visible"> <div class="my-alert-mask" @click="closeAlert"></div> <div class="my-alert-content"> <p>{{ message }}</p> <button @click="closeAlert">确定</button> </div> </div> </template> <script> export default { props: { message: { type: String, default: "", }, }, data() { return { visible: true, }; }, methods: { closeAlert() { this.visible = false; }, }, }; </script> <style scoped> .my-alert { position: fixed; top: 0; left: 0; right: 0; bottom: 0; } .my-alert-mask { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.5); } .my-alert-content { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background-color: #fff; } </style> ``` 2. 在需要弹出的地方使用该组件,并传递要显示的消息。 ``` <template> <div> <button @click="showAlert">弹出</button> <my-alert :message="alertMsg" v-if="isShowAlert" @closeAlert="isShowAlert=false"></my-alert> </div> </template> <script> import MyAlert from "./MyAlert.vue"; export default { components: { MyAlert, }, data() { return { isShowAlert: false, alertMsg: "", }; }, methods: { showAlert() { this.isShowAlert = true; this.alertMsg = "这是一个弹出"; }, }, }; </script> ``` 这样就可以实现一个简单的手写原生弹出。相比于使用浏览器的原生弹出,自定义的弹出更加灵活,并且可以根据需求进行自由扩展。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值