本组件基于 iCheck v1.0.2 创建,适用于 Angular2 及以上版本。
- 通过 NPM 安装 angular4-icheck 以及依赖包
npm install angular4-icheck --save
- 导入 ICheckModule 模块到项目的 app.module.ts
import { ICheckModule } from 'angular4-icheck';
@NgModule({
imports: [ ICheckModule.forRoot() ]
})
- 引入 iCheck 的层叠样式表到项目中,你可以在 /node_modules/angular4-icheck/skins/ 文件夹中找到所有的样式表,将其中你需要的样式表加入到你的HTML文档中。 例如加载红色扁平风格的样式:
<link href="node_modules/angular4-icheck/skins/flat/red.css" rel="stylesheet">
- 你也可以选择将他们加到 .angular-cli.json 文件的 styles 段:
"styles": [
"../node_modules/angular4-icheck/skins/flat/red.css"
],
- 在你的项目模板的单选或复选框代码中加入 icheck 属性,注意 iCheckClass 属性(以红色扁平风格的样式为例):
<input icheck iCheckClass="icheckbox_flat-red" type="checkbox">
<input icheck iCheckClass="icheckbox_flat-red" type="checkbox" checked>
<input icheck iCheckClass="iradio_flat-red" type="radio" name="exampleRadio">
<input icheck iCheckClass="iradio_flat-red" type="radio" name="exampleRadio" checked>
- 为了简化HTML,你可以在 ICheckModule 中进行全局配置
import { ICheckModule } from 'angular4-icheck';
@NgModule({
imports: [ ICheckModule.forRoot({
checkboxClass: 'icheckbox_flat-red',
radioClass: 'iradio_flat-red'
}) ]
})
模块支持的选项和组件属性
- handle: 'checkbox' | 'radio' | '', // 将 iCheck 应用到复选框 / 单选框 / 全部 ( 只能配置到Module Options,缺省全部 )
- checkboxClass: 'icheckbox', // 复选框默认样式
- radioClass: 'iradio', // 单选框默认样式
- checkedClass: 'checked', // 选中状态样式
- checkedCheckboxClass: '', // 复选框选中状态样式 ( 缺省会自动应用 checkedClass )
- checkedRadioClass: '', // 单选框选中状态样式 ( 缺省会自动应用 checkedClass )
- uncheckedClass: '', // 未选中状态样式
- uncheckedCheckboxClass: '', // 复选框未选中状态样式 ( 缺省会自动应用 uncheckedClass )
- uncheckedRadioClass: '', // 单选框未选中状态样式 ( 缺省会自动应用 uncheckedClass )
- disabledClass: 'disabled', // 禁用状态样式
- disabledCheckboxClass: '', // 复选框禁用状态样式 ( 缺省会自动应用 disabledClass )
- disabledRadioClass: '', // 单选框禁用状态样式 ( 缺省会自动应用 disabledClass )
- enabledClass: '', // 启用状态样式
- enabledCheckboxClass: '', // 复选框启用状态样式 ( 缺省会自动应用 enabledClass )
- enabledRadioClass: '', // 单选框启用状态样式 ( 缺省会自动应用 enabledClass )
- hoverClass: 'hover', // 鼠标滑入样式
- labelHover: true, // 是否将鼠标滑入样式应用到 label 标签
- labelHoverClass: 'hover', // 鼠标滑入时 label 标签样式
- 回调支持
- ifClicked: 当用户点击 iCheck 时触发
- ifChanged: 当 iCheck 在 checked / unchecked / disabled / enabled 状态变更时触发
- ifChecked: 当 iCheck 从 unchecked 变更为 checked 状态时触发
- ifUnchecked: 当 iCheck 从 checked 变更为 unchecked 状态时触发
- ifToggled: 当 iCheck 的 checked 状态发生变更时触发
- ifDisabled: 当 iCheck 从 enabled 变更为 disabled 状态时触发
- ifEnabled: 当 iCheck 从 disabled 变更为 enabled 状态时触发
- 应用回调用举例:
<input icheck type="checkbox" (ifToggled)="log($event)">
- 组件支持的外部方法调用
- check(): iCheck 状态变更为 checked
- uncheck(): iCheck 状态变更为 unchecked
- toggle(): iCheck 的 checked 状态反转
- disable(): iCheck 状态变更为 diabled
- enable(): iCheck 状态变更为 enable
- update(): 根据单选或复选框的当前状态更新模板
- 方法调用举例:
import { Component, AfterViewInit, ViewChild } from '@angular/core';
import { ICheckComponent } from 'angular4-icheck';
@Component({
select: 'app-root',
template: `
<label>
<input #exampleCheckbox icheck iCheckClass="icheckbox_flat-red" (ifChecked)="log($event)" type="checkbox">
Example Checkbox
</label>`
})
export class AppComponent implements AfterViewInit {
@ViewChild('exampleCheckbox') iCheckComponentRef: ICheckComponent;
ngAfterViewInit() {
this.iCheckComponentRef.check();
}
log(e) {
console.log('exampleCheckbox: ' + e.type.replace('if', '').toLowerCase());
}
}
Please leave your feedback if you have noticed any issues or have a feature request.
The repository code is open-sourced software licensed under the MIT license.