面向对象--封装弹出层

14 篇文章 15 订阅
1 篇文章 0 订阅
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
		<style type="text/css">
			.wrap{
				width: 300px;
				border-radius: 4px;
				box-shadow: 0 0 2px #333;
				background-color: #fff;
			}
			.header{
				background-color: #0078FF;
				border-top-left-radius: 5px;
				border-top-right-radius: 5px;
				color: #fff;
				display: flex;
				font-size: 20px;
				padding:10px;
			}
			.title{
				flex-grow: 1;
			}
			.close{
				flex-shrink: 0;
			}
			.content{
				min-height: 100px;
				padding:10px;
			}
		</style>
	</head>
	<body>
		<button type="button">打开</button>
		<script>
			// 封装弹出层
			function Tip(option){
				option=option||{}
				// 标签结构的标题
				this.title=option.title||'提示框';
				// 标签内容
				this.content=option.content||'';
				// 弹出层id
				this.index="id" +(new Date).getTime()
				// 标签结构
				this.el=this.initView();
				
			}
			Tip.prototype.initView=function(){
				var sCon=`
				<div class="wrap" id="${this.index}">
					<div class="header">
						<div class="title">${this.title}</div>
						<div class="close">X</div>
					</div>
					<div class="content">${this.content}</div>
				</div>
				`
				$(sCon).appendTo(document.body);
				$('#'+this.index).find('.close').click(()=>{
					this.hide()
				})
				
				return $('#'+this.index);
			}
			// 展示
			Tip.prototype.show=function(){
				this.el.show()
			}
			// 关闭
			Tip.prototype.hide=function(){
				this.el.hide()
			}
			// 获取单例单例
			function getSingleObj(callback){
				var obj =null;
				return function(option){
					return obj || (obj=new callback(option))
				}
			}
			// 获取创建弹出层的单例方法
			var createTip=getSingleObj(Tip)
			
			// 业务
			$('button:contains(打开)').click(function(){
				var tip=createTip({
				title:'警告框',
				content:'zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz'
			})
				tip.show()
			})
		</script>
	</body>
</html>

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值