slo*_*ope 4 javascript asynchronous redux redux-saga
所以我注释掉了它给我回溯的地方。
export function* watchFileReader(){
const action = yield take("DROP_FILE")
console.log('action', action)
let file = action.file[0];
readFile(file, function(e){
sessionStorage.removeItem('img')
console.log('alskdjfalsdjkf', e.target.result)
sessionStorage.setItem('img', e.target.result)
// yield put({type: "UDATE", {img: e.target.result})
})
}
Run Code Online (Sandbox Code Playgroud)
更新:这是我承诺的使代码起作用的功能。
function readFileWithPromise(file){
return new Promise((resolve, reject) => {
readFile(file, function(e){
if (e){
resolve(e)
}else{
reject(e)
}
})
})
}
Run Code Online (Sandbox Code Playgroud)
您不能在callback中使用yield,有两种方法可以避免这种情况:
cps效果。文档链接
import { cps , ... } from 'redux-saga/effects';
export function* watchFileReader(){
const action = yield take("DROP_FILE")
let file = action.file[0];
let e = yield cps(readFile,file); <----------------
sessionStorage.removeItem('img')
sessionStorage.setItem('img', e.target.result)
yield put({type: "UPDATE", img: e.target.result})
}
Run Code Online (Sandbox Code Playgroud)
注意:函数必须调用cb(null,result)来通知中间件成功的结果。如果fn遇到错误,则它必须调用cb(error)以便通知中间件已发生错误。
发挥 功能
function readFileWithPromise(file){
return new Promise((resolve,reject)=>{
readFile(file,(err, res) => err ? reject(err) : resolve(res));
});
}
Run Code Online (Sandbox Code Playgroud)
然后叫它
import { call, ... } from 'redux-saga/effects';
export function* watchFileReader(){
const action = yield take("DROP_FILE")
let file = action.file[0];
let e = yield call(readFileWithPromise,file); <----------------
sessionStorage.removeItem('img')
sessionStorage.setItem('img', e.target.result)
yield put({type: "UPDATE", img: e.target.result})
}
Run Code Online (Sandbox Code Playgroud)| 归档时间: |
|
| 查看次数: |
1192 次 |
| 最近记录: |