目前看ag2没有比较好的datetimepicker控件。研究了一下引用js版的bootstrap-daterangepicker.
1.首先配置daterangepicker js的依赖JS框架:
Date Range Picker relies onBootstrap,jQueryandMoment.js
angular-cli的官网是这么说的:
Global Library Installation
Some javascript libraries need to be added to the global scope,and loaded as if they were in a script tag. We can do this using theapps[0].scripts
andapps[0].styles
properties ofangular-cli.json
.
As an example,to useBootstrap 4this is what you need to do:
First install Bootstrap fromnpm
:
npm install bootstrap@next
Then add the needed script files toapps[0].scripts
:
"scripts": [ "../node_modules/jquery/dist/jquery.js","../node_modules/tether/dist/js/tether.js","../node_modules/bootstrap/dist/js/bootstrap.js" ],
Finally add the Bootstrap CSS to theapps[0].styles
array:
"styles": [ "../node_modules/bootstrap/dist/css/bootstrap.css","styles.css" ],
Restartng serve
if you're running it,and Bootstrap 4 should be working on your app.
不要用npm 下载 bootstrap,moment.直接把压缩包下载后,拷贝到对应的目录。
angular-cli.json中配置,全局的js
这个JQuery,Bootstrap要作为全局的JS进行安装.
在src目录下angular-cli.json文件中配置,全局的js:
"scripts": [ "assets/jquery/jquery-2.2.3.min.js","assets/bootstrap/js/bootstrap.min.js","assets/moment/moment.min.js","assets/daterangepicker/daterangepicker.js" ],
2.复制JQuery,boostrap,daterangepicker的相关CSS及JS
把jquery,bootstrap,daterangepicker的css及js复制到
src/assert目录结构如下:
3.配置JQuery和$的全局的变量
全局变量配置后,在TypeScript编译器就会认到这个变量,编译就不会报错。
在src的目录下新建:typings.d.ts
declare var $: any; declare var jQuery: any;
配置2个行记录保存。
4.配置CSS样式
到src目录的index.html文件中导入全局的css样式
<link href="assets/bootstrap/bootstrap.min.css" rel="stylesheet"> <link href="assets/font-awesome.min.css" rel="stylesheet"> <link href="assets/adminLTE/css/AdminLTE.min.css" rel="stylesheet" > <link href="assets/adminLTE/css/skins/skin-blue.min.css" rel="stylesheet"> <link href="assets/daterangepicker/daterangepicker.css" rel="stylesheet">
保存。
5.component组件中引用datatimerpicker
MainPageComponent 的代码:
import { Component,OnInit } from '@angular/core'; @Component({ selector: 'app-main-page',templateUrl: './main-page.component.html',styleUrls: ['./main-page.component.css'] }) export class MainPageComponent implements OnInit { /*private myDate:Date=new Date(); private date2:string; private time1:string;*/ constructor() { } ngOnInit() { this.dateRangePicker(); } dateRangePicker(){ let picker:any=$('#startEndTime'); let dataRageOption:Object={ "timePicker": true,"timePicker24Hour": true,"drops": "down","opens": "left","locale": { "format": "YYYY-MM-DD HH:mm:ss","separator": " -- ","applyLabel": "Apply","cancelLabel": "Cancel","fromLabel": "From","toLabel": "To","customRangeLabel": "Custom","daysOfWeek": [ "日","一","二","三","四","五","六" ],"monthNames": [ "一月","二月","三月","四月","五月","六月","7月","八月","九月","十月","十一月","十二月" ],"firstDay": 1 },"startDate": "2017-01-25 09:00:00","endDate": "2017-01-25 09:46:00" }; picker.daterangepicker(dataRageOption,function (start,end,label) { console.info(`start:${start.format('YYYY-MM-DD')},end:${end},label:${label}`); }); } }
main-page.html的代码:
<div class="form-group"> <label for="startEndTime" class="col-sm-1 control-label">开始结束时间</label> <div class="col-sm-7 input-group"> <input type="text" class="form-control" id="startEndTime" name="startEndTime" placeholder="开始-结束时间"> </div> </div>
显示效果
重启ng serve
在页面上就可以看到: