<center>JavaScript单列模式</center>

本文深入讲解单例模式的概念,通过生动的例子如账号注册和登录弹框来解释其工作原理。并通过JavaScript代码演示如何在实际应用中实现单例模式,确保类的唯一实例并允许全局访问。

单例模式概念
首先什么是单例模式?可以这样理解:单例模式旨在保证一个类仅有一个实例,并提供一个全局的访问点。

可能有人还是不太理解单例的概念,那么你可以想象生活中的一些例子。比如注册账号的时候,如果我们注册的账号已经存在,那么系统会提示我们“账号已经存在是否使用该账号登陆”,我们无法再次创建一个一模一样的账号,除非把原账号注销。这就是单例模式的生动体现。

类似的例子还有网页上的登陆弹框,无论我们点击多少次登陆按钮,界面上始终只会显示一个登陆弹框,无法再创建第二个。

本文就将以登陆弹框为例介绍单例模式的使用方式。

<!DOCTYPE html>
<html>
<head>
	<title></title>
	<style type="text/css">
		div{
			width: 200px;
			height: 200px;
			background: red;
		}
	</style>
</head>
<body>

<script type="text/javascript">

	//实战练习:  设计一个函数,创建一个弹出层。弹出层可以反复打开和关闭。 
	// function Popup(){
	// 	var div = document.createElement('div');
	// 	document.body.appendChild(div);
	// 	this.hide = function(){
	// 		div.style.display = "none";
	// 	};
	// 	this.show = function(){
	// 		div.style.display = "block";
	// 	}
	// };
	//下面对上面方法进行改进,单例模式要求new Popup()==new Popup(),本次还是没有实现单例模式
	 var Popup = (function(){
	 	var div = document.createElement('div');
	 	document.body.appendChild(div); 	
	 	return function(){
	 		this.hide = function(){
	 			div.style.display = "none";
	 		}
	 		this.show = function(){
	 			div.style.display = "block";
	 		}
	 	}
	 })();
	 console.log(new Popup()==new Popup())//false 通过闭包.并没有达到在同一个内存空间中
	// 再次改进
	var Popup = (function(){
		var div = document.createElement('div');
		document.body.appendChild(div);
		var instance = null;//返回的对象内存
		return function(name,age){
			if(instance==null){
				instance = {};
				instance.hide = function(){
					div.style.display = "none";
				}
				instance.show = function(){
					div.style.display = "block";
				}
			}
			return instance;			
		}
	})()

	// console.log(new Popup()==new Popup());true 达到效果

	//单例模式的好处
	function A(){
		var c = new Popup();//假设C是单例模式
		c.prop = 'xxxxx';
	}
	function B(){
		var c = new Popup();
		console.log(c.prop);

	}
	//单例模式:有一个构造函数:Conn,他的所有实例都指向同一个内存:节约内存,不同对象间属性可以共享

</script>
</body>
</html>
<p> <table border="1" cellpadding="0" cellspacing="0" width="1837" style="border-collapse:collapse;width:919pt;"> <tbody> <tr> <td height="66" class="oa1" width="279"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;font-weight:bold;">事项</span> </p> </td> <td class="oa1" width="387"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;font-weight:bold;line-height:1;">时间</span> </p> </td> <td class="oa1" width="456"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;font-weight:bold;line-height:1;">地点</span> </p> </td> <td class="oa1" width="348"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;font-weight:bold;line-height:1;">对接人</span> </p> </td> <td class="oa1" width="367"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;font-weight:bold;line-height:1;">工作内容</span> </p> </td> </tr> <tr> <td height="71" class="oa2" width="279"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">展品接寄</span> </p> </td> <td class="oa2" width="387"> <p style="text-align:center;margin-left:0in;text-indent:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">12</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">月</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">1</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">日 </span> </p> </td> <td class="oa2" width="456"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">B19</span> </p> </td> <td class="oa2" width="348"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">孙秀茹</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">/</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">谭倩</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">/</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">苗爽</span> </p> </td> <td class="oa3" width="367"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">接收并保管</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">11</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">个展品的快递</span> </p> </td> </tr> <tr> <td height="71" class="oa2" width="279"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">讲解员</span> </p> </td> <td class="oa2" width="387"> <p style="text-align:center;margin-left:0in;text-indent:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">12</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">月</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">3</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">日</span> </p> </td> <td class="oa2" width="456"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">B19</span> </p> </td> <td class="oa2" width="348"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">孙秀茹</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">/</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">苗爽</span> </p> </td> <td class="oa3" width="367"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">-</span> </p> </td> </tr> <tr> <td height="71" class="oa2" width="279"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">布展</span> </p> </td> <td class="oa2" width="387"> <p style="text-align:center;margin-left:0in;text-indent:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">12</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">月</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">3</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">日</span> </p> </td> <td class="oa2" width="456"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">B19</span> </p> </td> <td class="oa2" width="348"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">郭萌</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">/</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">孙秀茹</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">/</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">苗爽</span> </p> </td> <td class="oa3" width="367"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">①展板、支架、暗箱、展台制作</span> </p> </td> </tr> <tr> <td height="71" class="oa2" width="279"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">展区</span> </p> </td> <td class="oa2" width="387"> <p style="text-align:center;margin-left:0in;text-indent:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">13</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">:</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">3</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">0 </span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">- 1</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">6</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">:</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">40</span> </p> </td> <td class="oa2" width="456"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">报告厅门厅</span> </p> </td> <td class="oa2" width="348"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">孙秀茹</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">/</span><span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">苗爽</span> </p> </td> <td class="oa3" width="367"> <p style="text-align:center;margin-left:0in;"> <span style="font-size:12px;font-family:微软雅黑;color:black;line-height:1;">-</span> </p> </td> </tr> </tbody> </table> </p> 上面为邮件中table格式源码,请检查并优化
最新发布
11-21
<%-- Created by IntelliJ IDEA. User: Administrator Date: 2025/6/4 Time: 22:04 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ page import="java.sql.*"%> <html> <head> <title>Title</title> <style> body{ background-color: aquamarine; } .main{ background-color: antiquewhite; margin:0 auto; width:60%; padding-left: 40px; padding-right: 40px; } .main div{ background-color: #F0F8FF; padding:10px; } </style> </head> <body> <% response.setContentType("text/html;charset=UTF-8"); request.setCharacterEncoding("utf-8"); String bookid = request.getParameter("bookid"); Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost:3306/book"; String un = "root"; String pass = "root"; Connection con = DriverManager.getConnection(url,un,pass); String sql = "select * from books where id = ?" ; PreparedStatement pre = con.prepareStatement(sql); pre.setString(1,bookid); ResultSet rs = pre.executeQuery(); while(rs.next()){ String id = rs.getString("id"); String urls = rs.getString("url"); String name = rs.getString("bookname"); String writer = rs.getString("writer"); String syn = rs.getString("syn"); float price = rs.getFloat("price"); String stock = rs.getString("stock"); %> <form action="BOOKXIUGAI_OK.jsp?id=<%=id%>" method="post"> <div class="main"> <img src="<%=urls%>" width="180" height="256" alt="图片"/> <div>图片:<input type="text" name="urls" value="<%=urls%>"></div> <div>ID:<input type="text" name="id" disabled="disabled" value="<%=id%>"></div> <div>商品名:<input type="text" name="name" value="<%=name%>"></div> <div>品类:<input type="text" name="writer" value="<%=writer%>"></div> <div>简介:<textarea type="text" name="syn" rows="4" cols="50"><%=syn%></textarea></div> <div>价格:<input type="text" name="price" value="<%=price%>">元/件</div> <div> 库存:<input type="text" name="stock" value="<%=stock%>"></div> <div> <input type="submit" name="submit" value="提交"></div> <div> <a href="REMOVEBOOKS.jsp?id=<%=id%>">删除此书</a></div> <div><hr></div> </div> </form> <% }pre.close();rs.close(); %> </body> </html> 简单优化一下不要太复杂
06-13
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值