全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

由于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
     })]

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


# angular  # directive  # angularjs  # directive加载jquery插件  # 基于Angular.js实现的触摸滑动动画实例代码  # 利用angularjs1.4制作的简易滑动门效果  # 详解angularJs中自定义directive的数据交互  # AngularJS中的Directive自定义一个表格  # Angularjs使用directive自定义指令实现attribute继承的方法详解  # Angularjs自定义指令Directive详解  # angularjs利用directive实现移动端自定义软键盘的示例  # Angular.js通过自定义指令directive实现滑块滑动效果  # 自定义  # 回调  # 才会  # 所需  # 在上  # 所需要  # 来完成  # 创建一个  # 大家多多  # 时需  # 结束时间  # master  # bootstrap  # selector  # export  # dateRangePicker  # html 


相关文章: 南宁网站建设制作定制,南宁网站建设可以定制吗?  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  如何在七牛云存储上搭建网站并设置自定义域名?  建站之星后台密码如何安全设置与找回?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  如何在Tomcat中配置并部署网站项目?  教学网站制作软件,学习*后期制作的网站有哪些?  如何快速搭建安全的FTP站点?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  金*站制作公司有哪些,金华教育集团官网?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  如何选择靠谱的建站公司加盟品牌?  网站设计制作公司地址,网站建设比较好的公司都有哪些?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  建站之星云端配置指南:模板选择与SEO优化一键生成  建站之星伪静态规则如何正确配置?  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  如何高效配置香港服务器实现快速建站?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  宁波自助建站系统如何快速打造专业企业网站?  c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  建站168自助建站系统:快速模板定制与SEO优化指南  郑州企业网站制作公司,郑州招聘网站有哪些?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  如何用AWS免费套餐快速搭建高效网站?  建站之星备案是否影响网站上线时间?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  Swift中switch语句区间和元组模式匹配  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  焦点电影公司作品,电影焦点结局是什么?  小型网站制作HTML,*游戏网站怎么搭建?  电商网站制作公司有哪些,1688网是什么意思?  七夕网站制作视频,七夕大促活动怎么报名?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  建站主机选购指南与交易推荐:核心配置解析  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  宝塔建站后网页无法访问如何解决?  ,石家庄四十八中学官网?  如何破解联通资金短缺导致的基站建设难题?  建站之星各版本价格是多少?  网站制作公司排行榜,抖音怎样做个人官方网站  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  css网站制作参考文献有哪些,易聊怎么注册?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  小程序网站制作需要准备什么资料,如何制作小程序?  建站之星24小时客服电话如何获取? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。