详解angular2采用自定义指令(Directive)方式加载jquery插件


Posted in Javascript onFebruary 09, 2017

由于angular2兴起不久,相关插件还是很少,所以有时候不得不用一些jquery插件来完成项目,

那么如何把jquery插件放到angular2中呢?采用自定义指令!

在上下文之前要引入jquery,这点不再描述

首先创建一个指令,采用@input方式,来获取jquery插件所需要的参数。

在ngOnChanges时,也就是参数通过@input传入时,初始化jquery插件,

初始化jquery插件需要获取dom元素,所以我们引入ElementRef,用来获取dom元素

这里需要讲一下,jquery中回调函数,如果直接使用this,回调是无法获取angular的函数的

所以这里采用bind的形式,把this传递进去。这样在angular中的函数才会被正确调用。

以下为实现时间插件的代码:

import { Directive, Output, Input, ElementRef, EventEmitter } from '@angular/core';

// 引入jquery.daterangepicker插件相关JS和css,Css打包时需要打包成单个文件,或者直接在html单独引用
// 如何单独打包请看下节代码

require('../../../../assets/lib/bootstrap-daterangepicker-master/daterangepicker.js');
require('../../../../assets/lib/bootstrap-daterangepicker-master/daterangepicker.css');

// 自定义指令
@Directive({
 selector: '[dateRangePicker]',
})

export class DateRangePicker {

 /**
  * jquery.daterangepicker插件所需的参数
  * 参数:http://www.daterangepicker.com/#options
  */
 @Input() public dateRangePickerOptions: IJQueryDateRangePicker;

 // 选中事件
 @Output() selected: any = new EventEmitter();

 /**
  * 初始化
  * @param _elementRef
  */
 constructor(private _elementRef: ElementRef) {
 }

 /**
  * 属性发生更改时
  * @private
  */
 ngOnChanges() {
  $(this._elementRef.nativeElement).daterangepicker(this.dateRangePickerOptions, this.dateCallback.bind(this));
 }

 /**
  * 时间发生更改时使用emit传递事件
  * @private
  */
 dateCallback(start, end) {
  let format = "YYYY-MM-DD";
  if (this.dateRangePickerOptions.locale.format) {
   format = this.dateRangePickerOptions.locale.format;
  }
  let date = {
   startDate: start.format(format),
   endDate: end.format(format),
  }

  this.selected.emit(date);
 }

}
import { Component } from '@angular/core';
import { DateRangePicker } from '../../theme/directives';


@Component({
 selector: 'dashboard',
 template: `
   <div class="form-group">
        <label for="startDate">{date.startDate}</label>
        <input 
        dateRangePicker 
        [dateRangePickerOptions]="option"    
        (selected)="dateSelected($event)" 
        type="text" 
        class="form-control">
   </div>
 `,
 directives: [DateRangePicker]
})
export class Dashboard {

 /**
  * 当前选中的时间
  */
 public date: any

 /**
  * jquery时间插件参数
  */
 private option: Object = {
  locale: {
   format: "YYYY-MM-DD",
   separator: " 至 ",
   applyLabel: "确定",
   cancelLabel: '取消',
   fromLabel: '起始时间',
   toLabel: '结束时间',
   customRangeLabel: '自定义',
   daysOfWeek: ['日', '一', '二', '三', '四', '五', '六'],
   monthNames: ['一月', '二月', '三月', '四月', '五月', '六月',
    '七月', '八月', '九月', '十月', '十一月', '十二月'],
   firstDay: 1
  },
 };

 constructor() {
 }

 /**
  * emit回调事件,获取选中时间
  * @param date
  */
 dateSelected(date) {
  this.date = date;
 }
}

另外注意,css需要另外单独打包,或html单独引用,如何打包css,请看最后,我这里是用webpack打包的

// 采用ExtractTextPlugin单独对jquery插件进行css打包
loaders: [{
    test: /daterangepicker\.css$/,
    loader: ExtractTextPlugin.extract('style-loader', 'css-loader')
   }]

plugins: [
     new ExtractTextPlugin('[name].css', {
      allChunks: true
     })]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
使用Javascript和DOM Interfaces来处理HTML
Oct 09 Javascript
Add a Table to a Word Document
Jun 15 Javascript
javascript 关于# 和 void的区别分析
Oct 26 Javascript
javascript firefox 自动加载iframe 自动调整高宽示例
Aug 27 Javascript
js学习总结_选项卡封装(实例讲解)
Jul 13 Javascript
vue+ElementUI实现订单页动态添加产品数据效果实例代码
Jul 13 Javascript
vue-cli脚手架config目录下index.js配置文件的方法
Mar 13 Javascript
angular实现页面打印局部功能的思考与方法
Apr 13 Javascript
仿ElementUI实现一个Form表单的实现代码
Apr 23 Javascript
java和js实现的洗牌小程序
Sep 30 Javascript
Vue分页效果与购物车功能
Dec 13 Javascript
一起来了解一下JavaScript的预编译(小结)
Mar 01 Javascript
vue-router跳转页面的方法
Feb 09 #Javascript
基于JavaScript实现复选框的全选和取消全选
Feb 09 #Javascript
jquery.cookie.js的介绍与使用方法
Feb 09 #Javascript
js 数据存储和DOM编程
Feb 09 #Javascript
超全面的javascript中变量命名规则
Feb 09 #Javascript
简单的jQuery拖拽排序效果的实现(增强动态)
Feb 09 #Javascript
bootstrapValidator.min.js表单验证插件
Feb 09 #Javascript
You might like
linux php mysql数据库备份实现代码
2009/03/10 PHP
PHP获取一年中每个星期的开始和结束日期的方法
2015/02/12 PHP
PHP读取txt文本文件并分页显示的方法
2015/03/11 PHP
Yii2主题(Theme)用法详解
2016/07/23 PHP
总结PHP代码规范、流程规范、git规范
2018/06/18 PHP
Aptana调试javascript图解教程
2009/11/30 Javascript
js获取当月最后一天实例代码
2013/11/19 Javascript
jQuery的3种请求方式$.post,$.get,$.getJSON
2014/03/28 Javascript
JavaScript字符串对象toLowerCase方法入门实例(用于把字母转换为小写)
2014/10/17 Javascript
Javascript中Array用法实例分析
2015/06/13 Javascript
angularjs创建弹出框实现拖动效果
2020/08/25 Javascript
小白谈谈对JS原型链的理解
2016/05/03 Javascript
浅析创建javascript对象的方法
2016/05/13 Javascript
JS实现兼容各种浏览器的获取选择文本的方法【测试可用】
2016/06/21 Javascript
jQuery使用animate实现ul列表项相互飘动效果示例
2016/09/16 Javascript
AngularJS的Filter的示例详解
2017/03/07 Javascript
JavaScript转换数据库DateTime字段类型方法
2017/06/27 Javascript
解决在Bootstrap模糊框中使用WebUploader的问题
2018/03/22 Javascript
Vue实现远程获取路由与页面刷新导致404错误的解决
2019/01/31 Javascript
js实现文字头像的生成代码
2020/03/07 Javascript
python解析xml模块封装代码
2014/02/07 Python
Python实现繁?转为简体的方法示例
2018/12/18 Python
Django在Model保存前记录日志实例
2020/05/14 Python
python遍历路径破解表单的示例
2020/11/21 Python
新闻专业本科生的自我评价分享
2013/11/20 职场文书
后备干部考察材料
2014/02/12 职场文书
2014年社区植树节活动方案
2014/02/28 职场文书
农村党支部书记四风问题个人对照检查材料
2014/09/21 职场文书
刑事申诉状范文
2015/05/20 职场文书
2016年党员岗位承诺书
2016/03/24 职场文书
工作违纪的检讨书范文
2019/07/09 职场文书
SQL Server数据定义——模式与基本表操作
2021/04/05 SQL Server
python四个坐标点对图片区域最小外接矩形进行裁剪
2021/06/04 Python
Windows中Redis安装配置流程并实现远程访问功能
2021/06/07 Redis
Java Lambda表达式常用的函数式接口
2022/04/07 Java/Android
JavaScript原型链中函数和对象的理解
2022/06/16 Javascript