Jquery中$与$.fn的差别

当今web开发往往离不开Jquery的使用,Jquery以其简洁的使用方式、良好的浏览器兼容性赢得了软件研发同行的青睐,作为当中的一员,自然也不例外,虽然刚開始时非常排斥Jquery,今天我谈一下对Jquery中$与$.fn的认识和理解,不正确地方深望指正:

1、什么是$?

答:jquery的还有一种表现形式;

2、看以下的样例:

样例01:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>$与$.fn的差别——demo 01</title>

<script type="text/javascript" src="./jquery-1.6.2.js"></script>

<script type="text/javascript">

$.test = function(a,b) {

return a+b;

};

alert($.test(4,4));

</script>

</head>

<body>

</body>

</html>

样例02:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>$与$.fn的差别——demo 02</title>

<script type="text/javascript" src="./jquery-1.6.2.js"></script>

<script type="text/javascript">

$.extend({

test:function(a,b) {

return a+b;

}

});

alert($.test(4,4));

</script>

</head>

<body>

</body>

</html>

上面两个样例中的黄色背景出的代码有什么不同和同样?

答:除了功能同样以外最大的同样点在于调用函数(或方法)的方式同样;上面两个样例最大的不同点在于声明创建test方法的方式不同。

3、看以下的样例:

样例03:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>$与$.fn的差别——demo 03</title>

<script type="text/javascript" src="./jquery-1.6.2.js"></script>

<script type="text/javascript">

$.fn.test = function() {

return $(this).val();

};

$(function(){

alert($("#name").test());

});

</script>

</head>

<body>

<input type="hidden" id="name" name="name" value="高焕杰"/>

</body>

</html>

样例04:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>$与$.fn的差别——demo 04</title>

<script type="text/javascript" src="./jquery-1.6.2.js"></script>

<script type="text/javascript">

$.fn.extend({

test:function() {

return $(this).val();

}

});

$(function(){

alert($("#name").test());

});

</script>

</head>

<body>

<input type="hidden" id="name" name="name" value="高焕杰"/>

</body>

</html>

上面两个样例中的绿色背景出的代码有什么不同和同样?

答:除了功能同样以外最大的同样点在于调用函数(或方法)的方式同样;上面两个样例最大的不同点在于声明创建test方法的方式不同。

4、Jquery中$与$.fn的差别是什么?

答:在回答这个问题曾经,须要明白一个事实:Jquery的方法是能够拓展的,上面这4个样例都是对Jquery方法的拓展,从调用声明创建方法的方式来看,能够归结为两类:一类直接由$符调用;还有一类由$("")来调用,讲到这里你是不是想到了Java语言中的静态方法和实例方法,是的,假设从java类的角度认识调用创建的Jquery方法可能更好理解些,虽然Javascript没有明白的类的概念。好了如今能够回答问题了:$拓展的方法是静态方法,能够使用$直接调用,其拓展的方式有两种,一般使用$.extend({});;而$.fn拓展的方法是实例方法,必须由“对象”$("")来调用,其拓展的方式相同有两种,一般使用$.fn.extend({ })。

5、知识延展,到底什么是fn?

答:相同在回答这样一个问题曾经请打开一个Jquery文件(0分下载) 搜索这样一个字符“jQuery.prototype”,告诉我你看到了什么:jQuery.fn
= jQuery.prototype = {......},嗯嗯,也许你已经猜到了——fn就是prototype,是这样吗?请看以下的两个样例:

样例05:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>$与$.fn的差别——demo 05</title>

<script type="text/javascript" src="./jquery-1.6.2.js"></script>

<script type="text/javascript">

$.prototype.test = function() {

return $(this).val();

};

$(function(){

alert($("#name").test());

});

</script>

</head>

<body>

<input type="hidden" id="name" name="name" value="高焕杰"/>

</body>

</html>

样例06:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>$与$.fn的差别——demo 06</title>

<script type="text/javascript" src="./jquery-1.6.2.js"></script>

<script type="text/javascript">

$.prototype.extend({

test:function() {

return $(this).val();

}

});

$(function(){

alert($("#name").test());

});

</script>

</head>

<body>

<input type="hidden" id="name" name="name" value="高焕杰"/>

</body>

</html>

上面两个样例通过将fn改为prototype以后能够执行,呵呵呵,你猜对了。

0分下载demo:Jquery中$与$.fn的差别实例.zip

时间: 2024-10-05 18:07:16

Jquery中$与$.fn的差别的相关文章

JQuery中的each()的使用

each()函数是基本上所有的框架都提供了的一个工具类函数,通过它,你可以遍历对象.数组的属性值并进行处理. jQuery和jQuery对象都实现了该方法,对于jQuery对象,只是把each方法简单的进行了委托:把jQuery对象作为第一个参数传递给jQuery的each方法.换句话说:jQuery提供的each方法是对参数一提供的对象的中所有的子元素定州市科技工业局逐一进行方法调用.而jQuery对象提供的each方法则是对jQuery内部的子元素进行逐个调用. jQuery.prototy

jquery中filter(fn)的使用研究

jquery中filter(fn)给出的官方说明是: 筛选出与指定函数返回值匹配的元素集合 这个函数内部将对每个对象计算一次 (正如 '$.each'). 如果调用的函数返回false则这个元素被删除,否则就会保留. 这个说明没有问题,可是给出的例子却有问题.例子是 HTML 代码: <p><ol><li>Hello</li></ol></p><p>How are you?</p> jQuery 代码: $(&

Jquery中$与$.fn的区别

Jquery中$与$.fn的区别 当今web开发往往离不开Jquery的使用,Jquery以其简洁的使用方式.良好的浏览器兼容性赢得了软件研发同行的青睐,作为其中的一员,自然也不例外,尽管刚开始时很排斥Jquery,今天我谈一下对Jquery中$与$.fn的认识和理解,不对地方深望指正: 1.什么是$? 答:jquery的另一种表现形式: 2.看下面的例子: 例子01: 1 <html> 2 <head> 3 <meta http-equiv="Content-Ty

jQuery中的$.fn.data数据缓存

$.fn.data.$.fn.attr.$.fn.prop区别 $.fn.data.$.fn.attr.$.fn.prop的使用方法都差不多,但是他们的用法不一样. 1 <script src="jQuery.js"></script> 2 <div id="div"></div> 3 <script> 4 $(function(){ 5 var $div = $('#div'), 6 oDiv = doc

jquery的$.与$.fn的区别

这个是jquery插件的形式,举个例子: <div id="myDiv"></div> (function($){ $.fn.extend({ test:function(){ alert($(this).attr('id')); }})})(jQuery) $('#myDiv').test();打印出 : myDiv (function($){$.extend({test:function(){alert('111');}})})(jQuery)$.test(

jquery中的 $.fn $.fx

$.fn是指 jquery的命名空间,加上fn上的方法及属性,会对jquery实例每一个有效. 如扩展$.fn.abc() 那么你可以这样子:$("#div").abc(); 常使用extend方法扩展,详细请看API. $.fx是指 jquery的特效. 如果使用显示.滑动.淡入淡出.动画等.$.fx.off可以关闭动画,其实是直接显示结果.jquery的extend和fn.extendjQuery为开发插件提拱了两个方法,分别是: jQuery.fn.extend(object);

jQuery中的end()

要说end(),我们就不得不说prevObject. 在jQuery中,每个jQuery对象都有一个prevObject属性 var $p = $('p'); 这个属性是做什么的呢? jQuery内部维护着一个jQuery对象栈.每个遍历方法都会找到一组新元素(一个jQuery对象),然后jQuery会把这组元素推入到栈中. 可能上面这句话让人读起来有些茫然,不要紧,我们来一个例子: <!DOCTYPE html> <html lang="en"> <he

Angular和jQuery的ajax请求的差别

近期项目中使用angular,结果发现后台没法获取參数,所以,略微研究了一下两者在发送ajax时的差别. 注意angular和jquery的ajax请求是不同的. 在jquery中,官方文档解释contentType默认是 application/x-www-form-urlencoded; charset=UTF-8 contentType (default: 'application/x-www-form-urlencoded; charset=UTF-8') Type: String Wh

jQuery基础之(二)jQuery中的$

在jQuery中,最常用的莫过于使用美元符号$,它提供了各种各样的丰富功能.包括选择页面中一个或者一类元素.作为功能函数的前缀.windows.onload的完善,创建DOM节点等.本文介绍jQuery的用法.作为基础 1.选择器 在css中,选择器的作用是选择页面的某一类(类别选择器)元素或者某个(id选择器).而jQuery中的“$”作为选择器,同样是选择某类或者某个元素,只不过jQuery提供了更全面的选择方式.而且为用户处理了浏览器兼容问题. 例如在在css<h2>下的<a>