春天到了,各种绚丽的花朵都开放了,金黄的油菜花,成了蝴蝶的天地,美丽的蝴蝶在金黄色的舞台上跳着柔和而优美的舞姿。它们一会儿在空中飞舞,一会儿静静地停留在油菜花上。给春天增添了不少乐趣。油菜花的美丽,同时也吸引了不少 "劳动人民 "——蜜蜂,它们总是不分昼夜地不辞辛劳地给油菜花授粉。偶尔一阵微风吹来,金黄的油菜花立刻涌起了高低起伏的 "金浪花 "。远远望去,真是美不胜收!
由于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
})]
本文详解angular2采用自定义指令(Directive)方式加载jquery插件到此结束。你悟与不悟,道就在那里,不悲不喜。你修与不修,烦恼就在那里,不来不去。你明与无明,难题就在那里,不增不减。你观与不观,无常就在那里,不舍不弃。走进觉悟的道里,让觉悟住进心里,默然相契,一生自在欢喜。小编再次感谢大家对我们的支持!