LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

[点晴永久免费OA]【JavaScript】Jquery中的(function($){...})(jQuery)

admin
2023年4月28日 14:43 本文热度 782

        当你第一眼看到“(function($){...})(jQuery)”的时候。你有什么感觉?呵呵呵,我当时还是止不住的从心底里骂了一句——操,这他妈什么劳什子。时过境迁,对于如今无比倚重Jquery的我,自感当时的自己是那么的无知,今天忙里偷闲。解释一下到底“(function($){...})(jQuery)”该如何理解:


        代码一:

<html>
	<head>
		<title>代码一</title>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<script type="text/javascript">
			(function(name){
				alert(name);
			})("GaoHuanjie");
		</script>
	</head>
	<body>
	</body>
</html>


        说明:在浏览器中运行上面代码。会弹出一个对话框。对话框的内容为GaoHuanjie。

        上面代码中运行的Javascript脚本和“(function($){...})(jQuery)”是一样的。也就是说“(function($){...})(jQuery)”中的函数会自己主动被运行,那么到底该如何理解“(function($){...})(jQuery)”呢?“(function($){...})(jQuery)”实际上表示的是已处于调用状态的匿名函数:function($){...}是定义的匿名函数,參数为$(之所以将參数声明为$是为了不与其它库冲突);为了调用该函数则在该匿名函数的后面添上了括号和实參(这里为jQuery),但又由于操作符的优先级,函数本身也须要用括号,所以又为匿名函数加入了括号。

        释疑解惑:

        一、我运行以下代码为什么报错——jQuery is not defined:

<html>
	<head>
		<title>代码二</title>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<script type="text/javascript">
			(function($){
				alert($);
			})(jQuery);
		</script>
	</head>
	<body>
	</body>
</html>


        嗯嗯。浏览器在解析上述js脚本时确实会出现故障,假如为jQuery加入英文双引號,再次使用浏览器运行上述脚本则不会出错。为什么不加就会出错呢,呵呵呵,事实上这里的jQuery还是一个变量。假设为上述代码引入jQuery库,再次使用浏览器运行上述代码则不会出现故障:

<html>
	<head>
		<title>代码三</title>
		<script type="text/javascript" src="./jquery-1.6.2.js"></script>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<script type="text/javascript">
			(function($){
				alert($);
			})(jQuery);
		</script>
	</head>
	<body>
	</body>
</html>


        在引入jQuery库后之所以不会出错是由于jQuery库中定义了jQuery变量。


        二、和$(function(){ })相比,(function($){...})(jQuery)的运行时机也是在网页DOM载入完成后才运行吗?


        不是的,比方例如以下样例:

<html>
	<head>
		<title>代码四</title>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<script type="text/javascript">
			(function(){
				alert(document.getElementById("name").value);
			})();
		</script>
	</head>
	<body>
		<input type="hidden" id="name" name="name" value="GaoHuanjie" />
	</body>
</html>


        上述样例在浏览器中运行的时候会报错。究其原因(function(){...})()函数的运行时机并非在DOM载入完成后才运行,而是随着页面自上而下来运行,假设将其改成例如以下代码则再次使用浏览器运行脚本则不会出现故障:


<html>
	<head>
		<title>代码五</title>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
	</head>
	<body>
		<input type="hidden" id="name" name="name" value="GaoHuanjie" />
		<script type="text/javascript">
			(function(){
				alert(document.getElementById("name").value);
			})();
		</script>
	</body>
</html>


        一句话:“$(function(){ });”用于存放操作DOM对象的代码,运行当中代码时DOM对象已存在;“(function(){})(jQuery);”用于存放开发插件的代码,运行当中代码时DOM不一定存在。


该文章在 2023/4/28 14:53:01 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved