更新框架,内置Promise;组件支持slot
parent
fe90703b85
commit
a2d9603eaa
|
@ -40,14 +40,13 @@ const compileJs = (entry, output) => {
|
||||||
const compileCss = (entry, output) => {
|
const compileCss = (entry, output) => {
|
||||||
let t1 = Date.now()
|
let t1 = Date.now()
|
||||||
const { css } = scss.renderSync({ ...cssOpt, file: entry })
|
const { css } = scss.renderSync({ ...cssOpt, file: entry })
|
||||||
prefixer.process(css, { from: '', to: '' }).then(result => {
|
|
||||||
log(
|
log(
|
||||||
'编译scss: %s, 耗时 %s ms',
|
'编译scss: %s, 耗时 %s ms',
|
||||||
chalk.green(entry),
|
chalk.green(entry),
|
||||||
chalk.yellow(Date.now() - t1)
|
chalk.yellow(Date.now() - t1)
|
||||||
)
|
)
|
||||||
fs.echo(result.css, output)
|
fs.echo(css, output)
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const compileHtm = (entry, output) => {
|
const compileHtm = (entry, output) => {
|
||||||
|
|
File diff suppressed because one or more lines are too long
Binary file not shown.
File diff suppressed because one or more lines are too long
Binary file not shown.
358
src/js/anot.js
358
src/js/anot.js
|
@ -305,6 +305,244 @@ const _Anot = (function() {
|
||||||
|
|
||||||
/*-----------------部分ES6的JS实现 start---------------*/
|
/*-----------------部分ES6的JS实现 start---------------*/
|
||||||
|
|
||||||
|
// ===============================
|
||||||
|
// ========== Promise ============
|
||||||
|
// ===============================
|
||||||
|
;(function(nativePromise) {
|
||||||
|
function _yes(val) {
|
||||||
|
return val
|
||||||
|
}
|
||||||
|
|
||||||
|
function _no(err) {
|
||||||
|
throw err
|
||||||
|
}
|
||||||
|
|
||||||
|
function done(callback) {
|
||||||
|
return this.then(callback, _no)
|
||||||
|
}
|
||||||
|
|
||||||
|
function fail(callback) {
|
||||||
|
return this.then(_yes, callback)
|
||||||
|
}
|
||||||
|
|
||||||
|
function defer() {
|
||||||
|
var obj = {}
|
||||||
|
obj.promise = new _Promise(function(yes, no) {
|
||||||
|
obj.resolve = yes
|
||||||
|
obj.reject = no
|
||||||
|
})
|
||||||
|
return obj
|
||||||
|
}
|
||||||
|
|
||||||
|
//成功的回调
|
||||||
|
function _resolve(obj, val) {
|
||||||
|
if (obj._state !== 'pending') {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (val && typeof val.then === 'function') {
|
||||||
|
var method = val instanceof _Promise ? '_then' : 'then'
|
||||||
|
val[method](
|
||||||
|
function(v) {
|
||||||
|
_transmit(obj, v, true)
|
||||||
|
},
|
||||||
|
function(v) {
|
||||||
|
_transmit(obj, v, false)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
_transmit(obj, val, true)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//失败的回调
|
||||||
|
function _reject(obj, val) {
|
||||||
|
if (obj._state !== 'pending') {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
_transmit(obj, val, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 改变Promise的_fired值,并保持用户传参,触发所有回调
|
||||||
|
function _transmit(obj, val, isResolved) {
|
||||||
|
obj._fired = true
|
||||||
|
obj._val = val
|
||||||
|
obj._state = isResolved ? 'fulfilled' : 'rejected'
|
||||||
|
|
||||||
|
fireCallback(obj, function() {
|
||||||
|
for (var i in obj.callback) {
|
||||||
|
obj._fire(obj.callback[i].yes, obj.callback[i].no)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function fireCallback(obj, callback) {
|
||||||
|
var isAsync = false
|
||||||
|
|
||||||
|
if (typeof obj.async === 'boolean') {
|
||||||
|
isAsync = obj.async
|
||||||
|
} else {
|
||||||
|
isAsync = obj.async = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isAsync) {
|
||||||
|
setTimeout(callback, 0)
|
||||||
|
} else {
|
||||||
|
callback()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function _some(bool, iterable) {
|
||||||
|
iterable = Array.isArray(iterable) ? iterable : []
|
||||||
|
|
||||||
|
var n = 0
|
||||||
|
var res = []
|
||||||
|
var end = false
|
||||||
|
|
||||||
|
return new _Promise(function(yes, no) {
|
||||||
|
if (!iterable.length) no(res)
|
||||||
|
|
||||||
|
function loop(obj, idx) {
|
||||||
|
obj.then(
|
||||||
|
function(val) {
|
||||||
|
if (!end) {
|
||||||
|
res[idx] = val
|
||||||
|
n++
|
||||||
|
if (bool || n >= iterable.length) {
|
||||||
|
yes(bool ? val : res)
|
||||||
|
end = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function(val) {
|
||||||
|
end = true
|
||||||
|
no(val)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
for (var i = 0, len = iterable.length; i < len; i++) {
|
||||||
|
loop(iterable[i], i)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------
|
||||||
|
var _Promise = function(callback) {
|
||||||
|
this.callback = []
|
||||||
|
var _this = this
|
||||||
|
|
||||||
|
if (typeof this !== 'object') {
|
||||||
|
throw new TypeError('Promises must be constructed via new')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof callback !== 'function') {
|
||||||
|
throw new TypeError('Argument must be a function')
|
||||||
|
}
|
||||||
|
|
||||||
|
callback(
|
||||||
|
function(val) {
|
||||||
|
_resolve(_this, val)
|
||||||
|
},
|
||||||
|
function(val) {
|
||||||
|
_reject(_this, val)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
var self = {
|
||||||
|
_state: 1,
|
||||||
|
_fired: 1,
|
||||||
|
_val: 1,
|
||||||
|
callback: 1
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.prototype = {
|
||||||
|
constructor: _Promise,
|
||||||
|
_state: 'pending',
|
||||||
|
_fired: false,
|
||||||
|
_fire: function(yes, no) {
|
||||||
|
if (this._state === 'rejected') {
|
||||||
|
if (typeof no === 'function') no(this._val)
|
||||||
|
else throw this._val
|
||||||
|
} else {
|
||||||
|
if (typeof yes === 'function') yes(this._val)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_then: function(yes, no) {
|
||||||
|
if (this._fired) {
|
||||||
|
var _this = this
|
||||||
|
fireCallback(_this, function() {
|
||||||
|
_this._fire(yes, no)
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.callback.push({ yes: yes, no: no })
|
||||||
|
}
|
||||||
|
},
|
||||||
|
then: function(yes, no) {
|
||||||
|
yes = typeof yes === 'function' ? yes : _yes
|
||||||
|
no = typeof no === 'function' ? no : _no
|
||||||
|
var _this = this
|
||||||
|
var next = new _Promise(function(resolve, reject) {
|
||||||
|
_this._then(
|
||||||
|
function(val) {
|
||||||
|
try {
|
||||||
|
val = yes(val)
|
||||||
|
} catch (err) {
|
||||||
|
return reject(err)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function(val) {
|
||||||
|
try {
|
||||||
|
val = no(val)
|
||||||
|
} catch (err) {
|
||||||
|
return reject(err)
|
||||||
|
}
|
||||||
|
resolve(val)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
})
|
||||||
|
for (var i in _this) {
|
||||||
|
if (!self[i]) next[i] = _this[i]
|
||||||
|
}
|
||||||
|
return next
|
||||||
|
},
|
||||||
|
done: done,
|
||||||
|
catch: fail,
|
||||||
|
fail: fail
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.all = function(arr) {
|
||||||
|
return _some(false, arr)
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.race = function(arr) {
|
||||||
|
return _some(true, arr)
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.defer = defer
|
||||||
|
|
||||||
|
_Promise.resolve = function(val) {
|
||||||
|
var obj = this.defer()
|
||||||
|
obj.resolve(val)
|
||||||
|
return obj.promise
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.reject = function(val) {
|
||||||
|
var obj = this.defer()
|
||||||
|
obj.reject(val)
|
||||||
|
return obj.promise
|
||||||
|
}
|
||||||
|
if (/native code/.test(nativePromise)) {
|
||||||
|
nativePromise.prototype.done = done
|
||||||
|
nativePromise.prototype.fail = fail
|
||||||
|
if (!nativePromise.defer) {
|
||||||
|
nativePromise.defer = defer
|
||||||
|
}
|
||||||
|
}
|
||||||
|
window.Promise = nativePromise || _Promise
|
||||||
|
})(window.Promise)
|
||||||
|
|
||||||
if (!Object.assign) {
|
if (!Object.assign) {
|
||||||
Object.defineProperty(Object, 'assign', {
|
Object.defineProperty(Object, 'assign', {
|
||||||
enumerable: false,
|
enumerable: false,
|
||||||
|
@ -529,6 +767,33 @@ const _Anot = (function() {
|
||||||
|
|
||||||
/*-----------------部分ES6的JS实现 ending---------------*/
|
/*-----------------部分ES6的JS实现 ending---------------*/
|
||||||
|
|
||||||
|
function cacheStore(tpye, key, val) {
|
||||||
|
if (!window[tpye]) {
|
||||||
|
return log('该浏览器不支持本地储存' + tpye)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.type(key) === 'object') {
|
||||||
|
for (var i in key) {
|
||||||
|
window[tpye].setItem(i, key[i])
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
switch (arguments.length) {
|
||||||
|
case 2:
|
||||||
|
return window[tpye].getItem(key)
|
||||||
|
default:
|
||||||
|
if ((this.type(val) == 'string' && val.trim() === '') || val === null) {
|
||||||
|
window[tpye].removeItem(key)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (this.type(val) !== 'object' && this.type(val) !== 'array') {
|
||||||
|
window[tpye].setItem(key, val.toString())
|
||||||
|
} else {
|
||||||
|
window[tpye].setItem(key, JSON.stringify(val))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Anot.mix({
|
Anot.mix({
|
||||||
rword: rword,
|
rword: rword,
|
||||||
subscribers: subscribers,
|
subscribers: subscribers,
|
||||||
|
@ -671,55 +936,32 @@ const _Anot = (function() {
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* [ls localStorage操作]
|
* [ls localStorage操作]
|
||||||
* @param {[type]} name [键名]
|
* @param {[type]} key [键名]
|
||||||
* @param {[type]} val [键值,为空时删除]
|
* @param {[type]} val [键值,为空时删除]
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
ls: function(name, val) {
|
ls: function(key, val) {
|
||||||
if (!window.localStorage) {
|
return cacheStore('localStorage', key, val)
|
||||||
return log('该浏览器不支持本地储存localStorage')
|
},
|
||||||
}
|
ss: function(key, val) {
|
||||||
|
return cacheStore('sessionStorage', key, val)
|
||||||
if (this.type(name) === 'object') {
|
|
||||||
for (var i in name) {
|
|
||||||
localStorage.setItem(i, name[i])
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
switch (arguments.length) {
|
|
||||||
case 1:
|
|
||||||
return localStorage.getItem(name)
|
|
||||||
default:
|
|
||||||
if (
|
|
||||||
(this.type(val) == 'string' && val.trim() === '') ||
|
|
||||||
val === null
|
|
||||||
) {
|
|
||||||
localStorage.removeItem(name)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if (this.type(val) !== 'object' && this.type(val) !== 'array') {
|
|
||||||
localStorage.setItem(name, val.toString())
|
|
||||||
} else {
|
|
||||||
localStorage.setItem(name, JSON.stringify(val))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* [cookie cookie 操作 ]
|
* [cookie cookie 操作 ]
|
||||||
* @param name [cookie名]
|
* @param key [cookie名]
|
||||||
* @param value [cookie值]
|
* @param val [cookie值]
|
||||||
* @param {[json]} opt [有效期,域名,路径等]
|
* @param {[json]} opt [有效期,域名,路径等]
|
||||||
* @return {[boolean]} [读取时返回对应的值,写入时返回true]
|
* @return {[boolean]} [读取时返回对应的值,写入时返回true]
|
||||||
*/
|
*/
|
||||||
cookie: function(name, value, opt) {
|
cookie: function(key, val, opt) {
|
||||||
if (arguments.length > 1) {
|
if (arguments.length > 1) {
|
||||||
if (!name) {
|
if (!key) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
//设置默认的参数
|
//设置默认的参数
|
||||||
opt = opt || {}
|
opt = opt || {}
|
||||||
opt = this.mix(
|
opt = Object.assign(
|
||||||
{
|
{
|
||||||
expires: '',
|
expires: '',
|
||||||
path: '/',
|
path: '/',
|
||||||
|
@ -729,9 +971,9 @@ const _Anot = (function() {
|
||||||
opt
|
opt
|
||||||
)
|
)
|
||||||
|
|
||||||
if (!value) {
|
if ((this.type(val) == 'string' && val.trim() === '') || val === null) {
|
||||||
document.cookie =
|
document.cookie =
|
||||||
encodeURIComponent(name) +
|
encodeURIComponent(key) +
|
||||||
'=; expires=Thu, 01 Jan 1970 00:00:00 GMT; domain=' +
|
'=; expires=Thu, 01 Jan 1970 00:00:00 GMT; domain=' +
|
||||||
opt.domain +
|
opt.domain +
|
||||||
'; path=' +
|
'; path=' +
|
||||||
|
@ -755,9 +997,9 @@ const _Anot = (function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
document.cookie =
|
document.cookie =
|
||||||
encodeURIComponent(name) +
|
encodeURIComponent(key) +
|
||||||
'=' +
|
'=' +
|
||||||
encodeURIComponent(value) +
|
encodeURIComponent(val) +
|
||||||
opt.expires +
|
opt.expires +
|
||||||
'; domain=' +
|
'; domain=' +
|
||||||
opt.domain +
|
opt.domain +
|
||||||
|
@ -767,24 +1009,15 @@ const _Anot = (function() {
|
||||||
opt.secure
|
opt.secure
|
||||||
return true
|
return true
|
||||||
} else {
|
} else {
|
||||||
if (!name) {
|
if (!key) {
|
||||||
var keys = document.cookie
|
return document.cookie
|
||||||
.replace(
|
|
||||||
/((?:^|\s*;)[^\=]+)(?=;|$)|^\s*|\s*(?:\=[^;]*)?(?:\1|$)/g,
|
|
||||||
''
|
|
||||||
)
|
|
||||||
.split(/\s*(?:\=[^;]*)?;\s*/)
|
|
||||||
for (var i = 0, len = keys.length; i < len; i++) {
|
|
||||||
keys[i] = decodeURIComponent(keys[i])
|
|
||||||
}
|
|
||||||
return keys
|
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
decodeURIComponent(
|
decodeURIComponent(
|
||||||
document.cookie.replace(
|
document.cookie.replace(
|
||||||
new RegExp(
|
new RegExp(
|
||||||
'(?:(?:^|.*;)\\s*' +
|
'(?:(?:^|.*;)\\s*' +
|
||||||
encodeURIComponent(name).replace(/[\-\.\+\*]/g, '\\$&') +
|
encodeURIComponent(key).replace(/[\-\.\+\*]/g, '\\$&') +
|
||||||
'\\s*\\=\\s*([^;]*).*$)|^.*$'
|
'\\s*\\=\\s*([^;]*).*$)|^.*$'
|
||||||
),
|
),
|
||||||
'$1'
|
'$1'
|
||||||
|
@ -1527,7 +1760,7 @@ const _Anot = (function() {
|
||||||
$vmodel.$active = true
|
$vmodel.$active = true
|
||||||
$vmodel.mounted = mounted
|
$vmodel.mounted = mounted
|
||||||
|
|
||||||
if (old && old.$up) {
|
if (old && old.$up && old.$up.$children) {
|
||||||
old.$up.$children.push($vmodel)
|
old.$up.$children.push($vmodel)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3467,6 +3700,19 @@ const _Anot = (function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function parseSlot(collections) {
|
||||||
|
var arr = aslice.call(collections, 0)
|
||||||
|
var obj = {}
|
||||||
|
arr.forEach(function(elem) {
|
||||||
|
var slot = elem.getAttribute('slot')
|
||||||
|
if (slot) {
|
||||||
|
elem.removeAttribute('slot')
|
||||||
|
obj[slot] = elem.outerHTML
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return obj
|
||||||
|
}
|
||||||
|
|
||||||
Anot.components = {}
|
Anot.components = {}
|
||||||
Anot.component = function(name, opts) {
|
Anot.component = function(name, opts) {
|
||||||
if (opts) {
|
if (opts) {
|
||||||
|
@ -3531,16 +3777,20 @@ const _Anot = (function() {
|
||||||
componentWillMount.call(vmodel)
|
componentWillMount.call(vmodel)
|
||||||
globalHooks.componentWillMount.call(null, vmodel)
|
globalHooks.componentWillMount.call(null, vmodel)
|
||||||
|
|
||||||
if (!elem.content.firstElementChild) {
|
var slots = null
|
||||||
|
|
||||||
|
if (elem.content.firstElementChild) {
|
||||||
|
slots = parseSlot(elem.content.children)
|
||||||
|
}
|
||||||
|
|
||||||
Anot.clearHTML(elem)
|
Anot.clearHTML(elem)
|
||||||
var html = render.call(vmodel) || ''
|
var html = render.call(vmodel, slots) || ''
|
||||||
|
|
||||||
html = html.replace(/<\w+[^>]*>/g, function(m, s) {
|
html = html.replace(/<\w+[^>]*>/g, function(m, s) {
|
||||||
return m.replace(/[\n\t\s]{1,}/g, ' ')
|
return m.replace(/[\n\t\s]{1,}/g, ' ')
|
||||||
})
|
})
|
||||||
|
|
||||||
elem.innerHTML = html
|
elem.innerHTML = html
|
||||||
}
|
|
||||||
|
|
||||||
// 组件所使用的标签是temlate,所以必须要要用子元素替换掉
|
// 组件所使用的标签是temlate,所以必须要要用子元素替换掉
|
||||||
var child = elem.content.firstElementChild
|
var child = elem.content.firstElementChild
|
||||||
|
|
|
@ -320,6 +320,244 @@
|
||||||
|
|
||||||
/*-----------------部分ES6的JS实现 start---------------*/
|
/*-----------------部分ES6的JS实现 start---------------*/
|
||||||
|
|
||||||
|
// ===============================
|
||||||
|
// ========== Promise ============
|
||||||
|
// ===============================
|
||||||
|
;(function(nativePromise) {
|
||||||
|
function _yes(val) {
|
||||||
|
return val
|
||||||
|
}
|
||||||
|
|
||||||
|
function _no(err) {
|
||||||
|
throw err
|
||||||
|
}
|
||||||
|
|
||||||
|
function done(callback) {
|
||||||
|
return this.then(callback, _no)
|
||||||
|
}
|
||||||
|
|
||||||
|
function fail(callback) {
|
||||||
|
return this.then(_yes, callback)
|
||||||
|
}
|
||||||
|
|
||||||
|
function defer() {
|
||||||
|
var obj = {}
|
||||||
|
obj.promise = new _Promise(function(yes, no) {
|
||||||
|
obj.resolve = yes
|
||||||
|
obj.reject = no
|
||||||
|
})
|
||||||
|
return obj
|
||||||
|
}
|
||||||
|
|
||||||
|
//成功的回调
|
||||||
|
function _resolve(obj, val) {
|
||||||
|
if (obj._state !== 'pending') {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (val && typeof val.then === 'function') {
|
||||||
|
var method = val instanceof _Promise ? '_then' : 'then'
|
||||||
|
val[method](
|
||||||
|
function(v) {
|
||||||
|
_transmit(obj, v, true)
|
||||||
|
},
|
||||||
|
function(v) {
|
||||||
|
_transmit(obj, v, false)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
_transmit(obj, val, true)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//失败的回调
|
||||||
|
function _reject(obj, val) {
|
||||||
|
if (obj._state !== 'pending') {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
_transmit(obj, val, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 改变Promise的_fired值,并保持用户传参,触发所有回调
|
||||||
|
function _transmit(obj, val, isResolved) {
|
||||||
|
obj._fired = true
|
||||||
|
obj._val = val
|
||||||
|
obj._state = isResolved ? 'fulfilled' : 'rejected'
|
||||||
|
|
||||||
|
fireCallback(obj, function() {
|
||||||
|
for (var i in obj.callback) {
|
||||||
|
obj._fire(obj.callback[i].yes, obj.callback[i].no)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function fireCallback(obj, callback) {
|
||||||
|
var isAsync = false
|
||||||
|
|
||||||
|
if (typeof obj.async === 'boolean') {
|
||||||
|
isAsync = obj.async
|
||||||
|
} else {
|
||||||
|
isAsync = obj.async = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isAsync) {
|
||||||
|
setTimeout(callback, 0)
|
||||||
|
} else {
|
||||||
|
callback()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function _some(bool, iterable) {
|
||||||
|
iterable = Array.isArray(iterable) ? iterable : []
|
||||||
|
|
||||||
|
var n = 0
|
||||||
|
var res = []
|
||||||
|
var end = false
|
||||||
|
|
||||||
|
return new _Promise(function(yes, no) {
|
||||||
|
if (!iterable.length) no(res)
|
||||||
|
|
||||||
|
function loop(obj, idx) {
|
||||||
|
obj.then(
|
||||||
|
function(val) {
|
||||||
|
if (!end) {
|
||||||
|
res[idx] = val
|
||||||
|
n++
|
||||||
|
if (bool || n >= iterable.length) {
|
||||||
|
yes(bool ? val : res)
|
||||||
|
end = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function(val) {
|
||||||
|
end = true
|
||||||
|
no(val)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
for (var i = 0, len = iterable.length; i < len; i++) {
|
||||||
|
loop(iterable[i], i)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------
|
||||||
|
var _Promise = function(callback) {
|
||||||
|
this.callback = []
|
||||||
|
var _this = this
|
||||||
|
|
||||||
|
if (typeof this !== 'object') {
|
||||||
|
throw new TypeError('Promises must be constructed via new')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof callback !== 'function') {
|
||||||
|
throw new TypeError('Argument must be a function')
|
||||||
|
}
|
||||||
|
|
||||||
|
callback(
|
||||||
|
function(val) {
|
||||||
|
_resolve(_this, val)
|
||||||
|
},
|
||||||
|
function(val) {
|
||||||
|
_reject(_this, val)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
var self = {
|
||||||
|
_state: 1,
|
||||||
|
_fired: 1,
|
||||||
|
_val: 1,
|
||||||
|
callback: 1
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.prototype = {
|
||||||
|
constructor: _Promise,
|
||||||
|
_state: 'pending',
|
||||||
|
_fired: false,
|
||||||
|
_fire: function(yes, no) {
|
||||||
|
if (this._state === 'rejected') {
|
||||||
|
if (typeof no === 'function') no(this._val)
|
||||||
|
else throw this._val
|
||||||
|
} else {
|
||||||
|
if (typeof yes === 'function') yes(this._val)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_then: function(yes, no) {
|
||||||
|
if (this._fired) {
|
||||||
|
var _this = this
|
||||||
|
fireCallback(_this, function() {
|
||||||
|
_this._fire(yes, no)
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.callback.push({ yes: yes, no: no })
|
||||||
|
}
|
||||||
|
},
|
||||||
|
then: function(yes, no) {
|
||||||
|
yes = typeof yes === 'function' ? yes : _yes
|
||||||
|
no = typeof no === 'function' ? no : _no
|
||||||
|
var _this = this
|
||||||
|
var next = new _Promise(function(resolve, reject) {
|
||||||
|
_this._then(
|
||||||
|
function(val) {
|
||||||
|
try {
|
||||||
|
val = yes(val)
|
||||||
|
} catch (err) {
|
||||||
|
return reject(err)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function(val) {
|
||||||
|
try {
|
||||||
|
val = no(val)
|
||||||
|
} catch (err) {
|
||||||
|
return reject(err)
|
||||||
|
}
|
||||||
|
resolve(val)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
})
|
||||||
|
for (var i in _this) {
|
||||||
|
if (!self[i]) next[i] = _this[i]
|
||||||
|
}
|
||||||
|
return next
|
||||||
|
},
|
||||||
|
done: done,
|
||||||
|
catch: fail,
|
||||||
|
fail: fail
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.all = function(arr) {
|
||||||
|
return _some(false, arr)
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.race = function(arr) {
|
||||||
|
return _some(true, arr)
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.defer = defer
|
||||||
|
|
||||||
|
_Promise.resolve = function(val) {
|
||||||
|
var obj = this.defer()
|
||||||
|
obj.resolve(val)
|
||||||
|
return obj.promise
|
||||||
|
}
|
||||||
|
|
||||||
|
_Promise.reject = function(val) {
|
||||||
|
var obj = this.defer()
|
||||||
|
obj.reject(val)
|
||||||
|
return obj.promise
|
||||||
|
}
|
||||||
|
if (/native code/.test(nativePromise)) {
|
||||||
|
nativePromise.prototype.done = done
|
||||||
|
nativePromise.prototype.fail = fail
|
||||||
|
if (!nativePromise.defer) {
|
||||||
|
nativePromise.defer = defer
|
||||||
|
}
|
||||||
|
}
|
||||||
|
window.Promise = nativePromise || _Promise
|
||||||
|
})(window.Promise)
|
||||||
|
|
||||||
if (!Object.assign) {
|
if (!Object.assign) {
|
||||||
Object.defineProperty(Object, 'assign', {
|
Object.defineProperty(Object, 'assign', {
|
||||||
enumerable: false,
|
enumerable: false,
|
||||||
|
@ -544,6 +782,33 @@
|
||||||
|
|
||||||
/*-----------------部分ES6的JS实现 ending---------------*/
|
/*-----------------部分ES6的JS实现 ending---------------*/
|
||||||
|
|
||||||
|
function cacheStore(tpye, key, val) {
|
||||||
|
if (!window[tpye]) {
|
||||||
|
return log('该浏览器不支持本地储存' + tpye)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.type(key) === 'object') {
|
||||||
|
for (var i in key) {
|
||||||
|
window[tpye].setItem(i, key[i])
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
switch (arguments.length) {
|
||||||
|
case 2:
|
||||||
|
return window[tpye].getItem(key)
|
||||||
|
default:
|
||||||
|
if ((this.type(val) == 'string' && val.trim() === '') || val === null) {
|
||||||
|
window[tpye].removeItem(key)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if (this.type(val) !== 'object' && this.type(val) !== 'array') {
|
||||||
|
window[tpye].setItem(key, val.toString())
|
||||||
|
} else {
|
||||||
|
window[tpye].setItem(key, JSON.stringify(val))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Anot.mix({
|
Anot.mix({
|
||||||
rword: rword,
|
rword: rword,
|
||||||
subscribers: subscribers,
|
subscribers: subscribers,
|
||||||
|
@ -686,55 +951,32 @@
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* [ls localStorage操作]
|
* [ls localStorage操作]
|
||||||
* @param {[type]} name [键名]
|
* @param {[type]} key [键名]
|
||||||
* @param {[type]} val [键值,为空时删除]
|
* @param {[type]} val [键值,为空时删除]
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
ls: function(name, val) {
|
ls: function(key, val) {
|
||||||
if (!window.localStorage) {
|
return cacheStore('localStorage', key, val)
|
||||||
return log('该浏览器不支持本地储存localStorage')
|
},
|
||||||
}
|
ss: function(key, val) {
|
||||||
|
return cacheStore('sessionStorage', key, val)
|
||||||
if (this.type(name) === 'object') {
|
|
||||||
for (var i in name) {
|
|
||||||
localStorage.setItem(i, name[i])
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
switch (arguments.length) {
|
|
||||||
case 1:
|
|
||||||
return localStorage.getItem(name)
|
|
||||||
default:
|
|
||||||
if (
|
|
||||||
(this.type(val) == 'string' && val.trim() === '') ||
|
|
||||||
val === null
|
|
||||||
) {
|
|
||||||
localStorage.removeItem(name)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if (this.type(val) !== 'object' && this.type(val) !== 'array') {
|
|
||||||
localStorage.setItem(name, val.toString())
|
|
||||||
} else {
|
|
||||||
localStorage.setItem(name, JSON.stringify(val))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* [cookie cookie 操作 ]
|
* [cookie cookie 操作 ]
|
||||||
* @param name [cookie名]
|
* @param key [cookie名]
|
||||||
* @param value [cookie值]
|
* @param val [cookie值]
|
||||||
* @param {[json]} opt [有效期,域名,路径等]
|
* @param {[json]} opt [有效期,域名,路径等]
|
||||||
* @return {[boolean]} [读取时返回对应的值,写入时返回true]
|
* @return {[boolean]} [读取时返回对应的值,写入时返回true]
|
||||||
*/
|
*/
|
||||||
cookie: function(name, value, opt) {
|
cookie: function(key, val, opt) {
|
||||||
if (arguments.length > 1) {
|
if (arguments.length > 1) {
|
||||||
if (!name) {
|
if (!key) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
//设置默认的参数
|
//设置默认的参数
|
||||||
opt = opt || {}
|
opt = opt || {}
|
||||||
opt = this.mix(
|
opt = Object.assign(
|
||||||
{
|
{
|
||||||
expires: '',
|
expires: '',
|
||||||
path: '/',
|
path: '/',
|
||||||
|
@ -744,9 +986,9 @@
|
||||||
opt
|
opt
|
||||||
)
|
)
|
||||||
|
|
||||||
if (!value) {
|
if ((this.type(val) == 'string' && val.trim() === '') || val === null) {
|
||||||
document.cookie =
|
document.cookie =
|
||||||
encodeURIComponent(name) +
|
encodeURIComponent(key) +
|
||||||
'=; expires=Thu, 01 Jan 1970 00:00:00 GMT; domain=' +
|
'=; expires=Thu, 01 Jan 1970 00:00:00 GMT; domain=' +
|
||||||
opt.domain +
|
opt.domain +
|
||||||
'; path=' +
|
'; path=' +
|
||||||
|
@ -770,9 +1012,9 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
document.cookie =
|
document.cookie =
|
||||||
encodeURIComponent(name) +
|
encodeURIComponent(key) +
|
||||||
'=' +
|
'=' +
|
||||||
encodeURIComponent(value) +
|
encodeURIComponent(val) +
|
||||||
opt.expires +
|
opt.expires +
|
||||||
'; domain=' +
|
'; domain=' +
|
||||||
opt.domain +
|
opt.domain +
|
||||||
|
@ -782,24 +1024,15 @@
|
||||||
opt.secure
|
opt.secure
|
||||||
return true
|
return true
|
||||||
} else {
|
} else {
|
||||||
if (!name) {
|
if (!key) {
|
||||||
var keys = document.cookie
|
return document.cookie
|
||||||
.replace(
|
|
||||||
/((?:^|\s*;)[^\=]+)(?=;|$)|^\s*|\s*(?:\=[^;]*)?(?:\1|$)/g,
|
|
||||||
''
|
|
||||||
)
|
|
||||||
.split(/\s*(?:\=[^;]*)?;\s*/)
|
|
||||||
for (var i = 0, len = keys.length; i < len; i++) {
|
|
||||||
keys[i] = decodeURIComponent(keys[i])
|
|
||||||
}
|
|
||||||
return keys
|
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
decodeURIComponent(
|
decodeURIComponent(
|
||||||
document.cookie.replace(
|
document.cookie.replace(
|
||||||
new RegExp(
|
new RegExp(
|
||||||
'(?:(?:^|.*;)\\s*' +
|
'(?:(?:^|.*;)\\s*' +
|
||||||
encodeURIComponent(name).replace(/[\-\.\+\*]/g, '\\$&') +
|
encodeURIComponent(key).replace(/[\-\.\+\*]/g, '\\$&') +
|
||||||
'\\s*\\=\\s*([^;]*).*$)|^.*$'
|
'\\s*\\=\\s*([^;]*).*$)|^.*$'
|
||||||
),
|
),
|
||||||
'$1'
|
'$1'
|
||||||
|
@ -1542,7 +1775,7 @@
|
||||||
$vmodel.$active = true
|
$vmodel.$active = true
|
||||||
$vmodel.mounted = mounted
|
$vmodel.mounted = mounted
|
||||||
|
|
||||||
if (old && old.$up) {
|
if (old && old.$up && old.$up.$children) {
|
||||||
old.$up.$children.push($vmodel)
|
old.$up.$children.push($vmodel)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3482,6 +3715,19 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function parseSlot(collections) {
|
||||||
|
var arr = aslice.call(collections, 0)
|
||||||
|
var obj = {}
|
||||||
|
arr.forEach(function(elem) {
|
||||||
|
var slot = elem.getAttribute('slot')
|
||||||
|
if (slot) {
|
||||||
|
elem.removeAttribute('slot')
|
||||||
|
obj[slot] = elem.outerHTML
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return obj
|
||||||
|
}
|
||||||
|
|
||||||
Anot.components = {}
|
Anot.components = {}
|
||||||
Anot.component = function(name, opts) {
|
Anot.component = function(name, opts) {
|
||||||
if (opts) {
|
if (opts) {
|
||||||
|
@ -3546,16 +3792,20 @@
|
||||||
componentWillMount.call(vmodel)
|
componentWillMount.call(vmodel)
|
||||||
globalHooks.componentWillMount.call(null, vmodel)
|
globalHooks.componentWillMount.call(null, vmodel)
|
||||||
|
|
||||||
if (!elem.content.firstElementChild) {
|
var slots = null
|
||||||
|
|
||||||
|
if (elem.content.firstElementChild) {
|
||||||
|
slots = parseSlot(elem.content.children)
|
||||||
|
}
|
||||||
|
|
||||||
Anot.clearHTML(elem)
|
Anot.clearHTML(elem)
|
||||||
var html = render.call(vmodel) || ''
|
var html = render.call(vmodel, slots) || ''
|
||||||
|
|
||||||
html = html.replace(/<\w+[^>]*>/g, function(m, s) {
|
html = html.replace(/<\w+[^>]*>/g, function(m, s) {
|
||||||
return m.replace(/[\n\t\s]{1,}/g, ' ')
|
return m.replace(/[\n\t\s]{1,}/g, ' ')
|
||||||
})
|
})
|
||||||
|
|
||||||
elem.innerHTML = html
|
elem.innerHTML = html
|
||||||
}
|
|
||||||
|
|
||||||
// 组件所使用的标签是temlate,所以必须要要用子元素替换掉
|
// 组件所使用的标签是temlate,所以必须要要用子元素替换掉
|
||||||
var child = elem.content.firstElementChild
|
var child = elem.content.firstElementChild
|
||||||
|
@ -5811,7 +6061,9 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
oDate = new Date(stamp)
|
oDate = new Date(stamp)
|
||||||
if (oDate + '' === 'Invalid Date') return 'Invalid Date'
|
if (oDate + '' === 'Invalid Date') {
|
||||||
|
return 'Invalid Date'
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
oDate = stamp
|
oDate = stamp
|
||||||
}
|
}
|
||||||
|
@ -5867,9 +6119,7 @@
|
||||||
var ext = '.js' //默认拓展名
|
var ext = '.js' //默认拓展名
|
||||||
var res = 'js' // 默认资源类型
|
var res = 'js' // 默认资源类型
|
||||||
var suffix = ['.js', '.css']
|
var suffix = ['.js', '.css']
|
||||||
var cssfix = /\.(scss|sass|less)$/
|
|
||||||
name = name.replace(/\.[a-z0-9]+$/g, function(match) {
|
name = name.replace(/\.[a-z0-9]+$/g, function(match) {
|
||||||
match = match.replace(cssfix, '.css')
|
|
||||||
ext = match
|
ext = match
|
||||||
res = suffix.indexOf(match) > -1 ? match.slice(1) : 'text'
|
res = suffix.indexOf(match) > -1 ? match.slice(1) : 'text'
|
||||||
return ''
|
return ''
|
||||||
|
|
|
@ -51,22 +51,22 @@ function update(currPage, vm) {
|
||||||
}
|
}
|
||||||
|
|
||||||
const tmpls = {
|
const tmpls = {
|
||||||
home: `<button class="do-ui-font button home"
|
home: `<button class="do-icon-dbl-left button"
|
||||||
:css="{'border-radius': props.radius}"
|
:css="{'border-radius': props.radius}"
|
||||||
:attr-disabled="currPage === 1"
|
:attr-disabled="currPage === 1"
|
||||||
:data="{to: parseUrl(1)}"
|
:data="{to: parseUrl(1)}"
|
||||||
:click="setPage(1, $event)"></button>`,
|
:click="setPage(1, $event)"></button>`,
|
||||||
end: `<button class="do-ui-font button end"
|
end: `<button class="do-icon-dbl-right button"
|
||||||
:css="{'border-radius': props.radius}"
|
:css="{'border-radius': props.radius}"
|
||||||
:attr-disabled="currPage === totalPage"
|
:attr-disabled="currPage === totalPage"
|
||||||
:data="{to: parseUrl(totalPage)}"
|
:data="{to: parseUrl(totalPage)}"
|
||||||
:click="setPage(totalPage, $event)"></button>`,
|
:click="setPage(totalPage, $event)"></button>`,
|
||||||
prev: `<button class="do-ui-font button prev"
|
prev: `<button class="do-icon-left button"
|
||||||
:css="{'border-radius': props.radius}"
|
:css="{'border-radius': props.radius}"
|
||||||
:attr-disabled="{disabled: currPage < 2}"
|
:attr-disabled="{disabled: currPage < 2}"
|
||||||
:data="{to: parseUrl(currPage - 1)}"
|
:data="{to: parseUrl(currPage - 1)}"
|
||||||
:click="setPage(currPage - 1, $event)"></button>`,
|
:click="setPage(currPage - 1, $event)"></button>`,
|
||||||
next: `<button class="do-ui-font button next"
|
next: `<button class="do-icon-right button"
|
||||||
:css="{'border-radius': props.radius}"
|
:css="{'border-radius': props.radius}"
|
||||||
:attr-disabled="{disabled: currPage >= totalPage}"
|
:attr-disabled="{disabled: currPage >= totalPage}"
|
||||||
:data="{to: parseUrl(currPage + 1)}"
|
:data="{to: parseUrl(currPage + 1)}"
|
||||||
|
@ -83,7 +83,8 @@ const tmpls = {
|
||||||
total: `<span class="total-box">共 {{totalPage}} 页 {{totalItems}} 条</span>`,
|
total: `<span class="total-box">共 {{totalPage}} 页 {{totalItems}} 条</span>`,
|
||||||
jumper: `<div class="input-box">前往
|
jumper: `<div class="input-box">前往
|
||||||
<input type="text" :duplex="inputPage" :keyup="setPage(null, $event)"> 页
|
<input type="text" :duplex="inputPage" :keyup="setPage(null, $event)"> 页
|
||||||
</div>`
|
</div>`,
|
||||||
|
slot: `<slot name="extra" />`
|
||||||
}
|
}
|
||||||
|
|
||||||
export default Anot.component('pager', {
|
export default Anot.component('pager', {
|
||||||
|
@ -119,7 +120,7 @@ export default Anot.component('pager', {
|
||||||
delete props.color
|
delete props.color
|
||||||
delete props.size
|
delete props.size
|
||||||
},
|
},
|
||||||
render: function() {
|
render: function(slots) {
|
||||||
let { layout, theme, simpleMode } = this.props
|
let { layout, theme, simpleMode } = this.props
|
||||||
if (simpleMode) {
|
if (simpleMode) {
|
||||||
layout = ['prev', 'curr', 'next']
|
layout = ['prev', 'curr', 'next']
|
||||||
|
@ -130,7 +131,15 @@ export default Anot.component('pager', {
|
||||||
}
|
}
|
||||||
layout = layout.split(',')
|
layout = layout.split(',')
|
||||||
}
|
}
|
||||||
layout = layout.map(it => tmpls[it] || '')
|
layout = layout.map(it => {
|
||||||
|
if (it === 'slot') {
|
||||||
|
if (slots && slots.extra) {
|
||||||
|
return slots.extra
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return tmpls[it] || ''
|
||||||
|
}
|
||||||
|
})
|
||||||
return `
|
return `
|
||||||
<div
|
<div
|
||||||
class="do-pager do-fn-noselect"
|
class="do-pager do-fn-noselect"
|
||||||
|
|
|
@ -20,16 +20,8 @@
|
||||||
.button,.page {min-width:40px;height:40px}
|
.button,.page {min-width:40px;height:40px}
|
||||||
}
|
}
|
||||||
|
|
||||||
.button,.page {display:inline-block;border:0;color: nth($cgr, 1);text-decoration:none;cursor:pointer;vertical-align:top;font-size:14px;font-weight:100;
|
.button,.page {display:inline-block;border:0;color: nth($cgr, 1);text-decoration:none;cursor:pointer;vertical-align:top;font-size:14px;font-weight:100;}
|
||||||
|
.button {font-size:18px;}
|
||||||
&.home::after {content:"\e691";font-size:18px;}
|
|
||||||
&.prev::after {content:"\e67c";font-size:18px;}
|
|
||||||
&.next::after {content:"\e66e";font-size:18px;}
|
|
||||||
&.end::after {content:"\e693";font-size:18px;}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.curr, .disabled {cursor:default;}
|
.curr, .disabled {cursor:default;}
|
||||||
|
|
||||||
&.skin-1 {width:100%;
|
&.skin-1 {width:100%;
|
||||||
|
|
|
@ -1,231 +0,0 @@
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @authors yutent (yutent@doui.cc)
|
|
||||||
* @date 2016-11-26 16:35:45
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
var _Promise = function(callback) {
|
|
||||||
this.callback = []
|
|
||||||
var _this = this
|
|
||||||
|
|
||||||
if (typeof this !== 'object')
|
|
||||||
throw new TypeError('Promises must be constructed via new')
|
|
||||||
|
|
||||||
if (typeof callback !== 'function')
|
|
||||||
throw new TypeError('Argument must be a function')
|
|
||||||
|
|
||||||
callback(
|
|
||||||
function(val) {
|
|
||||||
_resolve(_this, val)
|
|
||||||
},
|
|
||||||
function(val) {
|
|
||||||
_reject(_this, val)
|
|
||||||
}
|
|
||||||
)
|
|
||||||
}
|
|
||||||
var self = {
|
|
||||||
_state: 1,
|
|
||||||
_fired: 1,
|
|
||||||
_val: 1,
|
|
||||||
callback: 1
|
|
||||||
}
|
|
||||||
|
|
||||||
_Promise.prototype = {
|
|
||||||
constructor: _Promise,
|
|
||||||
_state: 'pending',
|
|
||||||
_fired: false,
|
|
||||||
_fire: function(yes, no) {
|
|
||||||
if (this._state === 'rejected') {
|
|
||||||
if (typeof no === 'function') no(this._val)
|
|
||||||
else throw this._val
|
|
||||||
} else {
|
|
||||||
if (typeof yes === 'function') yes(this._val)
|
|
||||||
}
|
|
||||||
},
|
|
||||||
_then: function(yes, no) {
|
|
||||||
if (this._fired) {
|
|
||||||
var _this = this
|
|
||||||
fireCallback(_this, function() {
|
|
||||||
_this._fire(yes, no)
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
this.callback.push({ yes: yes, no: no })
|
|
||||||
}
|
|
||||||
},
|
|
||||||
then: function(yes, no) {
|
|
||||||
yes = typeof yes === 'function' ? yes : _yes
|
|
||||||
no = typeof no === 'function' ? no : _no
|
|
||||||
var _this = this
|
|
||||||
var next = new _Promise(function(resolve, reject) {
|
|
||||||
_this._then(
|
|
||||||
function(val) {
|
|
||||||
try {
|
|
||||||
val = yes(val)
|
|
||||||
} catch (err) {
|
|
||||||
return reject(err)
|
|
||||||
}
|
|
||||||
},
|
|
||||||
function(val) {
|
|
||||||
try {
|
|
||||||
val = no(val)
|
|
||||||
} catch (err) {
|
|
||||||
return reject(err)
|
|
||||||
}
|
|
||||||
resolve(val)
|
|
||||||
}
|
|
||||||
)
|
|
||||||
})
|
|
||||||
for (var i in _this) {
|
|
||||||
if (!self[i]) next[i] = _this[i]
|
|
||||||
}
|
|
||||||
return next
|
|
||||||
},
|
|
||||||
done: done,
|
|
||||||
catch: fail,
|
|
||||||
fail: fail
|
|
||||||
}
|
|
||||||
|
|
||||||
_Promise.all = function(arr) {
|
|
||||||
return _some(false, arr)
|
|
||||||
}
|
|
||||||
|
|
||||||
_Promise.race = function(arr) {
|
|
||||||
return _some(true, arr)
|
|
||||||
}
|
|
||||||
|
|
||||||
_Promise.defer = defer
|
|
||||||
|
|
||||||
_Promise.resolve = function(val) {
|
|
||||||
var obj = this.defer()
|
|
||||||
obj.resolve(val)
|
|
||||||
return obj.promise
|
|
||||||
}
|
|
||||||
|
|
||||||
_Promise.reject = function(val) {
|
|
||||||
var obj = this.defer()
|
|
||||||
obj.reject(val)
|
|
||||||
return obj.promise
|
|
||||||
}
|
|
||||||
|
|
||||||
// -----------------------------------------------------------
|
|
||||||
|
|
||||||
function _yes(val) {
|
|
||||||
return val
|
|
||||||
}
|
|
||||||
|
|
||||||
function _no(err) {
|
|
||||||
throw err
|
|
||||||
}
|
|
||||||
|
|
||||||
function done(callback) {
|
|
||||||
return this.then(callback, _no)
|
|
||||||
}
|
|
||||||
|
|
||||||
function fail(callback) {
|
|
||||||
return this.then(_yes, callback)
|
|
||||||
}
|
|
||||||
|
|
||||||
function defer() {
|
|
||||||
var obj = {}
|
|
||||||
obj.promise = new this(function(yes, no) {
|
|
||||||
obj.resolve = yes
|
|
||||||
obj.reject = no
|
|
||||||
})
|
|
||||||
return obj
|
|
||||||
}
|
|
||||||
|
|
||||||
//成功的回调
|
|
||||||
function _resolve(obj, val) {
|
|
||||||
if (obj._state !== 'pending') return
|
|
||||||
|
|
||||||
if (val && typeof val.then === 'function') {
|
|
||||||
var method = val instanceof _Promise ? '_then' : 'then'
|
|
||||||
val[method](
|
|
||||||
function(v) {
|
|
||||||
_transmit(obj, v, true)
|
|
||||||
},
|
|
||||||
function(v) {
|
|
||||||
_transmit(obj, v, false)
|
|
||||||
}
|
|
||||||
)
|
|
||||||
} else {
|
|
||||||
_transmit(obj, val, true)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//失败的回调
|
|
||||||
function _reject(obj, val) {
|
|
||||||
if (obj._state !== 'pending') return
|
|
||||||
|
|
||||||
_transmit(obj, val, false)
|
|
||||||
}
|
|
||||||
|
|
||||||
// 改变Promise的_fired值,并保持用户传参,触发所有回调
|
|
||||||
function _transmit(obj, val, isResolved) {
|
|
||||||
obj._fired = true
|
|
||||||
obj._val = val
|
|
||||||
obj._state = isResolved ? 'fulfilled' : 'rejected'
|
|
||||||
|
|
||||||
fireCallback(obj, function() {
|
|
||||||
for (var i in obj.callback) {
|
|
||||||
obj._fire(obj.callback[i].yes, obj.callback[i].no)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
function fireCallback(obj, callback) {
|
|
||||||
var isAsync = false
|
|
||||||
|
|
||||||
if (typeof obj.async === 'boolean') isAsync = obj.async
|
|
||||||
else isAsync = obj.async = true
|
|
||||||
|
|
||||||
if (isAsync) setTimeout(callback, 0)
|
|
||||||
else callback()
|
|
||||||
}
|
|
||||||
|
|
||||||
function _some(bool, iterable) {
|
|
||||||
iterable = Array.isArray(iterable) ? iterable : []
|
|
||||||
|
|
||||||
var n = 0
|
|
||||||
var res = []
|
|
||||||
var end = false
|
|
||||||
|
|
||||||
return new _Promise(function(yes, no) {
|
|
||||||
if (!iterable.length) no(res)
|
|
||||||
|
|
||||||
function loop(obj, idx) {
|
|
||||||
obj.then(
|
|
||||||
function(val) {
|
|
||||||
if (!end) {
|
|
||||||
res[idx] = val
|
|
||||||
n++
|
|
||||||
if (bool || n >= iterable.length) {
|
|
||||||
yes(bool ? val : res)
|
|
||||||
end = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
function(val) {
|
|
||||||
end = true
|
|
||||||
no(val)
|
|
||||||
}
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var i = 0, len = iterable.length; i < len; i++) {
|
|
||||||
loop(iterable[i], i)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------
|
|
||||||
|
|
||||||
var nativePromise = window.Promise
|
|
||||||
if (/native code/.test(nativePromise)) {
|
|
||||||
nativePromise.prototype.done = done
|
|
||||||
nativePromise.prototype.fail = fail
|
|
||||||
if (!nativePromise.defer) nativePromise.defer = defer
|
|
||||||
}
|
|
||||||
|
|
||||||
export default (window.Promise = nativePromise || _Promise)
|
|
|
@ -6,7 +6,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
'use strict'
|
'use strict'
|
||||||
import 'promise/index'
|
|
||||||
import Format from './lib/format'
|
import Format from './lib/format'
|
||||||
|
|
||||||
// 本地协议/头 判断正则
|
// 本地协议/头 判断正则
|
||||||
|
@ -173,8 +172,7 @@ class _Request {
|
||||||
//成功的回调
|
//成功的回调
|
||||||
let isSucc = isTimeout
|
let isSucc = isTimeout
|
||||||
? false
|
? false
|
||||||
: (this.transport.status >= 200 && this.transport.status < 300) ||
|
: this.transport.status >= 200 && this.transport.status < 400
|
||||||
this.transport.status === 304
|
|
||||||
|
|
||||||
let headers =
|
let headers =
|
||||||
(!isTimeout && this.transport.getAllResponseHeaders().split('\n')) || []
|
(!isTimeout && this.transport.getAllResponseHeaders().split('\n')) || []
|
||||||
|
@ -225,7 +223,11 @@ class _Request {
|
||||||
result.statusText = error[10012]
|
result.statusText = error[10012]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (result.status >= 200 && result.status < 400) {
|
||||||
this.defer.resolve(result)
|
this.defer.resolve(result)
|
||||||
|
} else {
|
||||||
|
this.defer.reject(result)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
delete this.transport
|
delete this.transport
|
||||||
delete this.opt
|
delete this.opt
|
||||||
|
|
|
@ -1,174 +0,0 @@
|
||||||
if ('object' != typeof JSON) {
|
|
||||||
JSON = {}
|
|
||||||
}
|
|
||||||
export default (function() {
|
|
||||||
'use strict'
|
|
||||||
function f(t) {
|
|
||||||
return 10 > t ? '0' + t : t
|
|
||||||
}
|
|
||||||
function this_value() {
|
|
||||||
return this.valueOf()
|
|
||||||
}
|
|
||||||
function quote(t) {
|
|
||||||
return (
|
|
||||||
(rx_escapable.lastIndex = 0),
|
|
||||||
rx_escapable.test(t)
|
|
||||||
? '"' +
|
|
||||||
t.replace(rx_escapable, function(t) {
|
|
||||||
var e = meta[t]
|
|
||||||
return 'string' == typeof e
|
|
||||||
? e
|
|
||||||
: '\\u' + ('0000' + t.charCodeAt(0).toString(16)).slice(-4)
|
|
||||||
}) +
|
|
||||||
'"'
|
|
||||||
: '"' + t + '"'
|
|
||||||
)
|
|
||||||
}
|
|
||||||
function str(t, e) {
|
|
||||||
var r,
|
|
||||||
n,
|
|
||||||
o,
|
|
||||||
u,
|
|
||||||
f,
|
|
||||||
a = gap,
|
|
||||||
i = e[t]
|
|
||||||
switch ((i &&
|
|
||||||
'object' == typeof i &&
|
|
||||||
'function' == typeof i.toJSON &&
|
|
||||||
(i = i.toJSON(t)),
|
|
||||||
'function' == typeof rep && (i = rep.call(e, t, i)),
|
|
||||||
typeof i)) {
|
|
||||||
case 'string':
|
|
||||||
return quote(i)
|
|
||||||
case 'number':
|
|
||||||
return isFinite(i) ? String(i) : 'null'
|
|
||||||
case 'boolean':
|
|
||||||
case 'null':
|
|
||||||
return String(i)
|
|
||||||
case 'object':
|
|
||||||
if (!i) return 'null'
|
|
||||||
if (
|
|
||||||
((gap += indent),
|
|
||||||
(f = []),
|
|
||||||
'[object Array]' === Object.prototype.toString.apply(i))
|
|
||||||
) {
|
|
||||||
for (u = i.length, r = 0; u > r; r += 1) f[r] = str(r, i) || 'null'
|
|
||||||
return (
|
|
||||||
(o =
|
|
||||||
0 === f.length
|
|
||||||
? '[]'
|
|
||||||
: gap
|
|
||||||
? '[\n' + gap + f.join(',\n' + gap) + '\n' + a + ']'
|
|
||||||
: '[' + f.join(',') + ']'),
|
|
||||||
(gap = a),
|
|
||||||
o
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if (rep && 'object' == typeof rep)
|
|
||||||
for (u = rep.length, r = 0; u > r; r += 1)
|
|
||||||
'string' == typeof rep[r] &&
|
|
||||||
((n = rep[r]),
|
|
||||||
(o = str(n, i)),
|
|
||||||
o && f.push(quote(n) + (gap ? ': ' : ':') + o))
|
|
||||||
else
|
|
||||||
for (n in i)
|
|
||||||
Object.prototype.hasOwnProperty.call(i, n) &&
|
|
||||||
((o = str(n, i)), o && f.push(quote(n) + (gap ? ': ' : ':') + o))
|
|
||||||
return (
|
|
||||||
(o =
|
|
||||||
0 === f.length
|
|
||||||
? '{}'
|
|
||||||
: gap
|
|
||||||
? '{\n' + gap + f.join(',\n' + gap) + '\n' + a + '}'
|
|
||||||
: '{' + f.join(',') + '}'),
|
|
||||||
(gap = a),
|
|
||||||
o
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var rx_one = /^[\],:{}\s]*$/,
|
|
||||||
rx_two = /\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,
|
|
||||||
rx_three = /"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,
|
|
||||||
rx_four = /(?:^|:|,)(?:\s*\[)+/g,
|
|
||||||
rx_escapable = /[\\"\u0000-\u001f\u007f-\u009f\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g,
|
|
||||||
rx_dangerous = /[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g
|
|
||||||
'function' != typeof Date.prototype.toJSON &&
|
|
||||||
((Date.prototype.toJSON = function() {
|
|
||||||
return isFinite(this.valueOf())
|
|
||||||
? this.getUTCFullYear() +
|
|
||||||
'-' +
|
|
||||||
f(this.getUTCMonth() + 1) +
|
|
||||||
'-' +
|
|
||||||
f(this.getUTCDate()) +
|
|
||||||
'T' +
|
|
||||||
f(this.getUTCHours()) +
|
|
||||||
':' +
|
|
||||||
f(this.getUTCMinutes()) +
|
|
||||||
':' +
|
|
||||||
f(this.getUTCSeconds()) +
|
|
||||||
'Z'
|
|
||||||
: null
|
|
||||||
}),
|
|
||||||
(Boolean.prototype.toJSON = this_value),
|
|
||||||
(Number.prototype.toJSON = this_value),
|
|
||||||
(String.prototype.toJSON = this_value))
|
|
||||||
var gap, indent, meta, rep
|
|
||||||
'function' != typeof JSON.stringify &&
|
|
||||||
((meta = {
|
|
||||||
'\b': '\\b',
|
|
||||||
' ': '\\t',
|
|
||||||
'\n': '\\n',
|
|
||||||
'\f': '\\f',
|
|
||||||
'\r': '\\r',
|
|
||||||
'"': '\\"',
|
|
||||||
'\\': '\\\\'
|
|
||||||
}),
|
|
||||||
(JSON.stringify = function(t, e, r) {
|
|
||||||
var n
|
|
||||||
if (((gap = ''), (indent = ''), 'number' == typeof r))
|
|
||||||
for (n = 0; r > n; n += 1) indent += ' '
|
|
||||||
else 'string' == typeof r && (indent = r)
|
|
||||||
if (
|
|
||||||
((rep = e),
|
|
||||||
e &&
|
|
||||||
'function' != typeof e &&
|
|
||||||
('object' != typeof e || 'number' != typeof e.length))
|
|
||||||
)
|
|
||||||
throw new Error('JSON.stringify')
|
|
||||||
return str('', { '': t })
|
|
||||||
})),
|
|
||||||
'function' != typeof JSON.parse &&
|
|
||||||
(JSON.parse = function(text, reviver) {
|
|
||||||
function walk(t, e) {
|
|
||||||
var r,
|
|
||||||
n,
|
|
||||||
o = t[e]
|
|
||||||
if (o && 'object' == typeof o)
|
|
||||||
for (r in o)
|
|
||||||
Object.prototype.hasOwnProperty.call(o, r) &&
|
|
||||||
((n = walk(o, r)), void 0 !== n ? (o[r] = n) : delete o[r])
|
|
||||||
return reviver.call(t, e, o)
|
|
||||||
}
|
|
||||||
var j
|
|
||||||
if (
|
|
||||||
((text = String(text)),
|
|
||||||
(rx_dangerous.lastIndex = 0),
|
|
||||||
rx_dangerous.test(text) &&
|
|
||||||
(text = text.replace(rx_dangerous, function(t) {
|
|
||||||
return '\\u' + ('0000' + t.charCodeAt(0).toString(16)).slice(-4)
|
|
||||||
})),
|
|
||||||
rx_one.test(
|
|
||||||
text
|
|
||||||
.replace(rx_two, '@')
|
|
||||||
.replace(rx_three, ']')
|
|
||||||
.replace(rx_four, '')
|
|
||||||
))
|
|
||||||
)
|
|
||||||
return (
|
|
||||||
(j = eval('(' + text + ')')),
|
|
||||||
'function' == typeof reviver ? walk({ '': j }, '') : j
|
|
||||||
)
|
|
||||||
throw new SyntaxError('JSON.parse')
|
|
||||||
})
|
|
||||||
return JSON
|
|
||||||
})()
|
|
Reference in New Issue