zs-mini-ali-ui
Version:
中视编译后版本 ali-ui
155 lines (147 loc) • 4.95 kB
JavaScript
;/******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ var __webpack_modules__ = ([
/* 0 */,
/* 1 */
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ fmtEvent)
/* harmony export */ });
function fmtEvent(props, e) {
var dataset = {};
for (var key in props) {
if (/data-/gi.test(key)) {
dataset[key.replace(/data-/gi, '')] = props[key];
}
}
return Object.assign({}, e, {
currentTarget: {
dataset: dataset
},
target: {
dataset: dataset,
targetDataset: dataset
}
});
}
/***/ })
/******/ ]);
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
(() => {
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _util_fmtEvent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1);
/**
* 对齐 ant design checkbox 的设计,增加 ctrlChecked 属性
* 当 props 中有 checked 传入时,am-checkbox 是非受控组件
* 当 props 中不传入 checked 而使用 ctrlChecked 时,am-checkbox 是受控组件
*/
Component({
props: {
value: '',
checked: false,
ctrlChecked: undefined,
disabled: false,
onChange: function onChange() {},
id: ''
},
data: {
// 组件内维护的 chackbox 勾选状态
_checked: false
},
onInit: function onInit() {
var checked = this.props.checked;
this.setData({
_checked: checked
});
},
didMount: function didMount() {
var checked = this.props.checked;
this.setData({
_checked: checked
});
},
// props 改变时
deriveDataFromProps: function deriveDataFromProps(nextProps) {
var _checked = this.data._checked;
var oldChecked = this.props.ctrlChecked;
var ctrlChecked = nextProps.ctrlChecked; // oldChecked===undefined 说明未传入 checked 属性,am-checkbox 将成为不受控组件
// oldChecked 有传入值 _checked 受外部 checked 属性控制
if (_checked !== ctrlChecked && oldChecked !== undefined) {
this.setData({
_checked: ctrlChecked
});
}
},
methods: {
onChange: function onChange(e) {
var _e$detail = e.detail,
detail = _e$detail === void 0 ? {} : _e$detail;
var value = detail.value;
this.setData({
_checked: value
});
var event = (0,_util_fmtEvent__WEBPACK_IMPORTED_MODULE_0__["default"])(this.props, e);
this.props.onChange(event);
}
}
});
})();
/******/ })()
;