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
         })]
时间: 2024-08-08 17:24:01

angular2采用自定义指令(Directive)方式加载jquery插件的相关文章

加载jquery插件注意了

1.尽量放在</body>之前,不要放在</head>标签之前,如果执意要放也要放在css之后,例如: <link href="style.css" .../> <script src=jquery.js></script> 2.加载方式使用异步加载,异步加载并不是以下的这种 <script type="text/javascript" src="jquery.js"><

angular directive 自定义指令--属性方式简单学习

1. 自定义指令 - @directive import { Component, Directive, HostListener, ElementRef } from '@angular/core' @Directive({ selector: '[input-trim]', host: { '(keyup)': 'keyUpFunc($event.target)', '(click)': 'onClick($event.target)', 'role-data': 'input-trim'

Android批量图片加载经典系列——采用二级缓存、异步加载网络图片

一.问题描述 Android应用中经常涉及从网络中加载大量图片,为提升加载速度和效率,减少网络流量都会采用二级缓存和异步加载机制,所谓二级缓存就是通过先从内存中获取.再从文件中获取,最后才会访问网络.内存缓存(一级)本质上是Map集合以key-value对的方式存储图片的url和Bitmap信息,由于内存缓存会造成堆内存泄露, 管理相对复杂一些,可采用第三方组件,对于有经验的可自己编写组件,而文件缓存比较简单通常自己封装一下即可.下面就通过案例看如何实现网络图片加载的优化. 二.案例介绍 案例新

vue自定义指令(Directive中的clickoutside.js)的理解

.array p { counter-increment: longen; margin-left: 10px } .array p::before { content: counter(longen) "." } .alink { font-size: 16px; color: blue } 阅读目录 vue自定义指令clickoutside.js的理解 回到顶部 vue自定义指令clickoutside.js的理解 vue自定义指令请看如下博客: vue自定义指令 一般在需要 DO

post方式加载iframe

最近开发遇到一个问题,数据库某个字段里面存着整个html代码.需求是预览的时候需要可视化,将html直接展示到页面. 那么问题来了: 1.需要展示的html中的样式会与外面的页面冲突. 2.直接加载数据中的html,可能存着一些脚本错误. 首先想到的解决办法是用iframe,但是iframe是直接加载某个页面. 想到的方法是: iframe加载一个空页面,将HTML代码直接填充到空页面,然后显示. 这种方式可以成功.然而因为某些原因html代码不能再次从数据库读取,html代码参数需要传递,然而

能否使用require(&#39;.json&#39;)的方式加载大量JSON文件?

Node.js中推崇非阻塞I/O,但是require一个模块时却是同步调用的,这会带来性能上的开销,但并不是每次require都很耗时,因为在require成功之后会缓存起来,在此加载时直接从缓存读取,并没有额外开销. 当通过.json的方式加载文件时,固然方便,但大量使用时会导致这些数据被缓存.大量数据会驻留在内存中,导致GC频繁和内存泄漏. 摘自:<技术之瞳> 能否使用require('.json')的方式加载大量JSON文件?

AngularJS之基础-5 路由(定义路由、使用路由)、自定义指令(Directive)

一.定义路由 ng-view - AngularJS 支持通过在单页面上的多个视图的单页应用 - ng-view 标记只是简单地创建一个占位符 - 使用 ng-template - 创建使用script标签的HTML视图 - 使用 - 定义类型作为主模块中 ng-template 的脚本块 $routeProvider - 映射相应的HTML页面或ng-template - 附加一个控制器使用相同键的服务   - 注意: - 需要angular-route.js脚本文件的引用 二.使用路由 锚点

页面第一次加载实现图片淡入方式加载

页面第一次加载实现图片淡入方式加载:图片以淡入方式加载总是让人感觉有一种动态的感觉,可以让用户体验更好,下面就简单介绍一下如何实现此效果.当页面加载的时候,让加载好的图片先隐藏,然后再使用fadeIn()函数实现图片的淡入效果,参考代码如下: <script type="text/javascript"> $("#load img").load(function() { $(this).hide(); $(this).fadeIn("5000&

Unity两中方式加载图片

看到草羊发的图片,也是真懒. 想起来当时写天气预报现在都忘干净了,好记性不如烂笔头,还是应该多记.自己打下来好了 using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; using System.IO; public class readPictures : MonoBehaviour { private Image ima