美文网首页Angular2.0我爱编程
Angular2中如何使用jquery

Angular2中如何使用jquery

作者: 杀个程序猿祭天 | 来源:发表于2018-04-11 10:55 被阅读40次

Angular2中如何使用jquery

Angular2是以TypeScript语言作为默认编码语言,所以你看到的全部都是.ts结尾的文件。

那什么是TypeScript

首先,它是一个编译型语言;既然是编译型,那么你像重构、导航、智能提醒这种工具属性就可以发挥出来,所以你会发现使用VS CODE来写Angular简直就是绝配。

同时,TypeScript还带来一些ES6/7才有特性,比如let、const、async等,你无须关心ES几。

最霸气,TypeScript还是一个强类型、泛型、多态等一些面向对象编程的东西。

那,为何我们不选它呢?

当然,说了这么多,这跟主题看似无关,但如果你了解这些,才能看到问题的本质

首先,第一关键点编译型,既然是编译型,那么你在代码中出现的任何变量、类、函数都是必须要存在,否则TA就会在编译时报错但,问题来了,现在的JavaScript世界中已经有那么多现成的第三方库,难道说都不能用了?非也!

TypeScript一开始就照顾这些了,所以就会有一个叫.d.ts的声明文件。MS当然不会让你去编写这一个文件,所以就有一个叫http://definitelytyped.org/ 网站,TA汇集了很多现成类库的第三方.d.ts的声明文件提供我们下载。

方法一

当然是使用最正规军了,用命令安装jQuery的声明文件。

npm install -D @types/jquery

以及使用

import * as $ from 'jquery';

$('body').addClass('');

完美的智能提示,如果你在VS CODE下的话。

方法二

对于一些并未提供 .d.ts 声明文件的类库,我们怎么办?那当然只能自己写了。

什么?自己写?很困难吧!很复杂吧!

没那么一回事,声明文件其实是对一些类库接口的描述,以下是我截取一段jQuery声明文件的部分代码

interface JQueryStatic {

    /**

     * 去掉字符串首尾空格

     *

     * @param str 字符串

     * @see {@link https://api.jquery.com/jQuery.trim/}

     */

    trim(str: string): string;

}

declare var $: JQueryStatic;

我还特意译成中文,这里的含量很少,最关键的就是 declare 它就是把一个变量 $ 定义成类型 JQueryStatic (还是个接口)。

这样,TS编译器在遇到 $ 时会去找该类型,并且你的代码里面不能出现 $.time1() 之类的,因为你的接口,只有一个 $.trim()。

等等,jQuery几十个接口,我都要这么写吗?

NO!!!当然不是,除非你想写一个又漂亮、又好看、又是中文、又是完美智能提示的声明文件的话。

否则,你那就拿 any 类型吧,TA就是万能货。你不需要写一个很复杂的声明文件,只需要:

declare var $: any;

简单粗暴有效!

结论

哎~其实是因群里每天都可以看到一句【怎么使用jQuery】;虽然最简单的结果只需要一句话 declare var $: any;,但我还是啰里吧嗦将了一大堆,可不把前因后果将清楚,我烦~。

另,此解只是抛砖引玉,在很多类库中都是通用的办法。但我建议还是找一些Angular2类库来使用,因为如何更有效的管理JavaScript运行,是一门学问。

希望此篇对你的帮助,快乐编程!

转载github Roy9218PP 

个人建议Angular2中不要使用jquery,会出现浏览器加载缓冲期,第一次打开页面jQuery效果不出现,再次刷新才会出现,在windows10上面会出现火狐浏览器不兼容,这种问题很奇怪,两个相同的版本的火狐在window10和window7出现的效果不同,window10则会出现不兼容的现象.

相关文章

  • Angular2中如何使用jquery

    Angular2中如何使用jquery Angular2是以TypeScript语言作为默认编码语言,所以你看到的...

  • 前端JS进阶五(原型)

    Zepto中如何使用原型 Zepto使用原型源码分析 jQuery中如何使用原型 jQuery使用原型源码分析 原...

  • Angular2如何使用jQuery

    Angular2是以TypeScript语言作为默认编码语言,所以你看到的全部都是.ts结尾的文件。 那什么是Ty...

  • Angular2 -与jQuery集成

    前言 在项目开发中往往会遇到一些场景不得不使用jQuery,但是angular2项目常常使用typescript。...

  • 3.5 使用 Angular2 框架

    3.5 使用 Angular2 框架 问题一:如何接入Angular2 框架? 由于 Angular2 项目中采用...

  • angular2 使用jQuery

    1.拿到我们的jquery.js文件放到自己的目录中 请随意,下面是我的目录 2.引入我们的jquery.js文件...

  • jQuery的基本使用

    这篇来说如何来使用jQuery? Ⅰ、jQuery的引入 ①一般引入:使用jQuery只需要在页面的 中引入jQu...

  • jQuery事件绑定

    jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用 在1.7之前的版本中jQuery处理事件有多个方法...

  • 前端基础入门五(掌握jQuery的常用api,实现动态效果)

    jQuery基本概念 学习目标:学会如何使用jQuery,掌握jQuery的常用api,能够使用jQuery实现常...

  • jQuery习题汇总

    1.如何使用jQuery获取页面中id为xxx的元素? 答:$('#xxx')或jQuery('#xxx') 2....

网友评论

    本文标题:Angular2中如何使用jquery

    本文链接:https://www.haomeiwen.com/subject/nfjahftx.html