分析jQuery创建实例与原型继承是如何处理的

作者:小菜 更新时间:2025-03-16 点击数:
简介:在普通情况下我们要用原生类、或者自定义类创建实例要用new运算符,使构造函数创建一个实例,并且实例继承构造器prototype上的所有公有方法。

如 new O

【菜科解读】

在普通情况下我们要用原生类、或者自定义类创建实例要用new运算符,使构造函数创建一个实例,并且实例继承构造器prototype上的所有公有方法。

如 new Object()、new Date()等等!(object有{},数组有[]这样的快捷方式 ,我们主要探讨new这种方式。

我们在使用jQuery时从来没有使用过new,他是不是用其他方法来生成实例呢?是不是没有使用prototype属性呢?事实上他都有使用,只是内部处理的非常巧妙,提高了使用的爽快度。

我们来看看他的源码

funtion jQuery( selector, context){ return new jQuery.fn.init( selector, context );

这里可以看出jQuery是有构造函数的,也是用了new 创建实例的。

那么jQuery.fn是什么呢?后面有个这样的处理:

jQuery.fn = jQuery.prototype={ init:function (){}}

这样我们就明白了,jQuery的构造函数是他原型上的init方法,而不是function jQuery。

这样的话每次调用$()他都会用jQuery原型上的init创建一个实例,那么新的问题来了。

如果用init创建实例的话,这个对象继承的是init的prototype上的方法而不会继承jQuery prototype上的方法,那么他是怎么实现原型继承的呢?

jQuery.fn.init.prototype = jQuery.fn;

这里他有一个这样的处理,把jQuery.fn赋值给了jQuery.fn.init.prototype ,这一步很关键。

我门看看这些是什么。

jQuery.fn是jQuery.prototype

jQuery.fn.init.prototype是jQuery.prototype.init.prototype

这个处理相当于

jQuery.prototype = jQuery.prototype.init.prototype

那么每当我们调用$()是,jQuery就会用new运算符调用他prototype上的init创建一个实例,这个由init创建实例会继承jQuery protype上的所有方法,并且这个实例的__proto__内部属性会指向jQuery的prototype属性。

另外我们注意到这个处理:

jQuery.fn = jQuery.prototype

这是他为了避免频繁的操作jQuery.prototype,所以用jQuery.fn缓存了jQuery.prototype。

这些的处理实在是非常巧妙,内部处理了实例创建不用使用者用new去生成实例,又非常漂亮的处理了prototype保证多实例共享方法减少资源开支,约翰哥真的不简单。

分析,jQuery,创建,实例,与,原型,继承,是,怎么,

使用jquery和MySql创建一个ajax关键词数据搜索

在web开发过程当中,我们经常需要在前台页面输入关键词进行数据的搜索,我们通常使用的搜索方式是将搜索结果用另一个页面显示,这样的方式对于搭建高性能网站来说不是最合适的,今天给大家分享一下如何使用 jQuery,MySQL 和 Ajax创建简单和有吸引力的Ajax 搜索,希望大家在开发项目的时候能够根据自己的实际情况灵活运用。

点击搜索默认显示所有的结果输入A之后显示的搜索结果输入 p之后显示的搜索结果没有找到相关的搜索词页面演示-点击下面的搜索按钮搜索数据文件结构 主要用到几个文件 index.php首页 dbcon.php数据库连接文件 search.php搜索处理页面第一步创建一个ajax_search的数据库,紧接着创建一个ajax_search表CREATE TABLE `ajax_search` ( `id` int(11) NOT NULL auto_increment, `FirstName` varchar(50) NOT NULL, `LastName` varchar(50) NOT NULL, `Age` int(11) NOT NULL, `Hometown` varchar(50) NOT NULL, `Job` varchar(50) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ;HTML :index.php--程序主页面DB Connect:dbcon.php--数据库连接文件 ?php //数据库连接函数 $link = mysql_connect(‘localhost‘, ‘root‘, ‘你的密码‘); mysql_select_db(‘ajax_demo‘,$link);//选择数据库连接?>搜索结果页面search.php代码如下 ?phpfunction checkValues($value) // 使用此函数对所有这些值都要检查防止 sql 注入和跨站点脚本 //除去字符串开头和末尾的空格或其他字符 $value = trim($value); // Stripslashes if (get_magic_quotes_gpc()) { //删除由 addslashes() 函数添加的反斜杠,该函数用于清理从数据库或 HTML 表单中取回的数据。

$value = stripslashes($value); //转换所有的 , 字符 $value = strtr($value,array_flip(get_html_translation_table(HTML_ENTITIES))); // 剥去 HTML的标签 $value = strip_tags($value); // 引用值 $value = mysql_real_escape_string($value); return $value;include("dbcon.php");//加载数据库连接文件$rec = checkValues($_REQUEST[‘val‘]);//获取table内容if($rec) $sql = "select * from ajax_search where FirstName like ‘%$rec%‘ or LastName like ‘%$rec%‘ or Age like ‘%$rec%‘ or Hometown like ‘%$rec%‘"; $sql = "select * from ajax_search";$rsd = mysql_query($sql);//查询这条语句$total = mysql_num_rows($rsd);//返回结果集中行的数目if($total==0){ echo ‘No Record Found !‘;}?>checkValues函数过滤字符串防止sql注入和跨站点脚本攻击,mysql_query($sql);用来查询语句,mysql_fetch_assoc()用来循环输出结果,怎么样是不是很简单,如果你的项目有需要,可以直接使用这个代码。

使用,jquery,和,MySql,创建,一个,ajax,关

MFC单文档创建一个新半透明窗口实例代码

在工程中新建一个类CChildFrameclass CChildFrame : public CFrameWnd在构造函数中:1 CChildFrame::CChildFrame()3 Create(NULL,"MFC Tutorial Part 1 CoderSource Window");4 }可选:添加WM_PAINT消息: 1 void CChildFrame::OnPaint() 3 CPaintDC dc(this); // device context for painting 5 // TODO: Add your message handler code here 6 CDC *pDC = GetDC(); 8 CBrush brush(RGB(0, 0, 0)); 9 CBrush *pOldBrush = pDC->SelectObject( 10 pDC->Rectangle(0, 0, 500, 500);11 pDC->SelectObject(pOldBrush);12 // Do not call CFrameWnd::OnPaint() for painting messages13 }在CXXApp类中,添加CChildFrame 指针变量:1 class CXXApp : public CWinApp3 public:4 CChildFrame *m_pChildWnd;6 ...7 }在CXXApp类的InitInstance 方法中添加: 1 BOOL CMultilayerDisplayApp::InitInstance() 3 ... 5 m_pChildWnd = new CChildFrame(); // 创建新窗口类对象 6 //////// 这部分用于透明此窗口对象关联的窗口/////////// 7 //加入WS_EX_LAYERED扩展属性 8 SetWindowLong(m_pChildWnd->m_hWnd, GWL_EXSTYLE, GetWindowLong(m_pChildWnd->m_hWnd, GWL_EXSTYLE)^0x80000); 9 HINSTANCE hInst = LoadLibrary("User32.DLL");10 if (hInst)12 typedef BOOL (WINAPI *MYFUNC)(HWND,COLORREF,BYTE,DWORD);13 MYFUNC fun = NULL;14 //取得SetLayeredWindowAttributes函数指针15 fun = (MYFUNC)GetProcAddress(hInst, "SetLayeredWindowAttributes");16 if (fun)18 fun(m_pChildWnd->m_hWnd, 0, 128, 2);20 FreeLibrary(hInst);22 //////// 这部分用于透明此窗口对象关联的窗口///////////24 // The one and only window has been initialized, so show and update it.25 m_pMainWnd->ShowWindow(SW_SHOW);26 m_pMainWnd->UpdateWindow();28 m_pChildWnd->ShowWindow(SW_SHOW);29 m_pChildWnd->UpdateWindow();31 return TRUE;33 效果如下: MFC,单文档,单,文档,创建,一个,新,半透明,窗口,
加入收藏
               

分析jQuery创建实例与原型继承是如何处理的

点击下载文档

格式为doc格式

  • 账号登录
社交账号登录