jQuery技术

[译稿]微软将 jQuery IntelliSense整合到Visual Studio

字号+ 作者:H5之家 来源:H5之家 2017-04-12 17:03 我要评论( )

上个月,我在博客里宣布了微软将对jQuery提供支持。在过去的几个星期里,我们与jQuery开发团队合作,在Studio2008和VisualWebDeveloper2008Express版本(免费的

[译稿]微软将 jQuery IntelliSense整合到Visual Studio

条评论

上个月,我在博客里宣布了微软将对jQuery提供支持。在过去的几个星期里,我们与jQuery开发团队合作,在Studio 2008 和 Visual Web Developer 2008 Express版本(免费的)中增加了很好的jQuery intellisense支持。现在这个支持可以下载使用了。

在VS 2008中启用jQuery Intellisense的步骤

要在VS中启用jQuery的intellisense完成,你要遵循三个步骤:

第一步: 安装VS 2008 SP1

VS 2008 SP1 在Visual Studio中加了更丰富的JavaScript intellisense支持,对很大部分的JavaScript库加了代码完成支持。

你可以在这里下载VS 2008 SP1 和 Visual Web Developer 2008 Express SP1。

第二步: 安装VS 2008 Patch KB958502以支持"-vsdoc.js"Intellisense文件

2 个星期前,我们发布了一个补丁,你可以将其运用到VS 2008 SP1 和 VWD 2008 Express SP1版本上,该补丁会导致Visual Studio在一个JavaScript库被引用时,查找是否存在一个可选的"-vsdoc.js"文件,如果存在的话,就用它来驱动 JavaScript intellisense引擎。

这些加了注释的"-vsdoc.js"文件可以包含对JavaScript方法提供了帮助文档的XML注释,以及对无法自动推断出的动态JavaScript签名的另外的代码intellisense提示。你可以在这里了解该补丁的详情。你可以在这里免费下载该补丁。

第三步: 下载jQuery-vsdoc.js文件

我们与jQuery开发团队合作编写了一个jQuery-vsdoc.js文件,该文件对串连的jQuery selector方法的JavaScript intellisense提供了帮助注释和支持。你可以在jQuery.com网站的上下载jQuery和jQuery-vsdoc文件:

把jquery-vsdoc.js保存到你项目中jquery.js文件所在的同一个目录中(同时确认它的命名前缀与jquery文件名匹配):

然后你可以象这样,通过一个html <script/>元素来引用标准的jquery文件:

或者也可以使用<asp:scriptmanager/> 控件来引用它,或者在一个单独的.js文件的顶部加 /// <reference/> 注释来引用它:

在完成之后,VS就会在你引用的脚本文件所在的同一个目录中寻找一个-vsdoc.js文件,如果找到的话,就会用它来做帮助和intellisense。

例如,我们可以使用jQuery来做一个基于JSON的get请求,得到该方法的intellisense(挂在$.之后):

以及 $.getJSON()方法参数的帮助/intellisense:

 

如果你在方法调用中嵌套回调函数的话,intellisense依旧会工作。例如,我们也许想对从服务器返回的每个JSON对象进行迭代:

对每个项,我们可以执行另一个嵌套的回调函数:

我们可以使用each回调函数动态地往列表中附加一个新图片(图片的src属性将指向返回的JSON媒体图片的URL):

然后在每个动态生成的图片上,我们可以连接一个点击事件处理函数,在点击时,会通过动画效果来消失:

注意jQuery intellisense在我们代码的每一个层次都很干净地做了提示。

JavaScript Intellisense 技巧和诀窍

Web工具开发团队的Jeff King本星期早先时候撰写了一个很棒的贴子,对有关VS 2008中JavaScript intellisense工作原理的若干常见的问题做了回答,我高度推荐阅读该文。

他 谈到的一个诀窍(我要在这里做示范)是在你想要在用户控件/部分(.ascx文件)中使用JavaScript intellisense时可以使用的一个技术。经常地,你不想要在这些文件中包括对JavaScript库的<script src=""/> 引用,这些引用往往是存在于使用了用户控件的母版页或内容网页之上的。当然,问题是,你这么做的话,在默认情形下VS是无法知道用户控件中用到了这个脚 本,因此不会为你提供intellisense 。

启用intellisense的一个方法是,在你的用户控件中加<script src=""/>元素,但在其周围加一个服务器端的<% if %> 块,在运行时其值总是为false:

在运行时,ASP.NET不会显示这个脚本标识(因为是包含在一个总是为false的if块中的),但是,VS却会运算这个<script/>标识,在用户控件中为它提供intellisense。在象用户控件这样的场景下,这是个非常有用的技术。Jeff在他的FAQ贴子和原先的jQuery intellisense贴子里还有更多细节。Rick Strahl在这里也有一篇很好的贴子,是关于使用jQuery intellisense的。

更多信息

想进一步了解jQuery的话,我建议观看Stephen Walther在PDC大会上做的《ASP.NET和jQuery》讲座。点击这里下载他的代码例程和 powerpoint讲义。

Rick Strahl也有一篇非常棒的《Introduction to jQuery》文章,讨论如何在 ASP.NET使用jQuery。Karl Seguin 在这里和这里有2篇非常好的jQuery基础教程贴子,对如何使用jQuery的一些基本知识提供了比较简短的的概述。

我也高度推荐《 jQuery in Action》一书。

希望本文对你有所帮助,

Scott
翻译:Scott Guthrie 博客中文版

访问:

微软中国官方商城

[广告]投资优惠入口:

买美股,上老虎 - 超低佣金,每股只需1美分

责任编辑:ugmbbc

对文章打分

[译稿]微软将 jQuery IntelliSense整合到Visual Studio

10 (91%)

1 (9%)

评论 ()

登录:

  • 新浪微博
  • 腾讯QQ
  • 最新

    最新资讯

    加载中...

    热门评论

    Top 10

    本周 本月

  • [视频]申通快递分拣机器人效率惊人:70%人工下岗

    阅读 (172517) 评论 (208)

  • 墨西哥地铁加入男性专座 直视性骚扰问题

    阅读 (114675) 评论 (30)

  • Galaxy S8玩《王者荣耀》类游戏:视野可以说是作弊

    阅读 (85009) 评论 (93)

  • [视频]申通快递分拣机器人效率惊人:70%人工下岗

    阅读 (172517) 评论 (208)

  • 外媒热议中国极客“女神”鼓励女性从事技术工作

    阅读 (137932) 评论 (146)

  • 墨西哥地铁加入男性专座 直视性骚扰问题

    阅读 (114675) 评论 (30)

  • 招聘

    推荐阅读

  • 宇宙第一IDE:Visual Studio 2017升级版发布

  • teikaei
  • 4 天前
  • Visual Studio 2017官方海报上线:展示诸多新特性和使用技巧

  • study875
  • 2017-3-14 10:12
  • 开发者 Insider?微软悄然推出 Visual Studio Preview 项目

  • raymon725
  • 2017-3-10 10:35
  • 微软正式发布Visual Studio 2017 专业/企业/社区版均已开放下载

  • raymon725
  • 2017-3-8 08:47
  • [下载]微软发布 Visual Studio for Mac 第四预览版

  • raymon725
  • 2017-3-8 08:27
  • 4850元起 Visual Studio 2017专业版悄然开卖

  • ugmbbc
  • 2017-3-8 06:45
  • 微软即将发布Visual Studio 2017

  • teikaei
  • 2017-3-7 14:53
  • 20周年献礼:Visual Studio 2017正式版3月7日发布

  • ugmbbc
  • 2017-2-10 07:01
  • Visual Studio 2017 即将迎来 RTM

  • raymon725
  • 2017-2-7 16:18

     

    1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

    相关文章
    网友点评