javascript - 怎么将一个函数内部的事件监听函数返回的值返回出来
高洛峰
高洛峰 2017-04-11 11:12:37
[JavaScript讨论组]

1.代码如下,我希望从seclect中返回请求成功后取得的结果,请求是异步的,有什么办法或者替代办法?

2.

function select(key,store) {   // 怎么保证这个异步结果的返回...
    var request3 = store.get(key);

      request3.onerror = function(event) {
          console.log("Error : " + event.errorCode);
      };
      request3.onsuccess = function(event) {
          return event.target.result;
      };
}
高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(2)
迷茫

1.回调函数

function select(key,store, callback) {
    var request3 = store.get(key);

      request3.onerror = function(event) {
          console.log("Error : " + event.errorCode);
      };
      request3.onsuccess = function(event) {
          callback(event.target.result);
      };
}

// 调用
select(key,store, function(result) {
    console.log(result)
})

2.Promise

function select(key,store, onsuccess) {
    var request3 = store.get(key);
    
    return new Promise(function(resolve, reject) {
          request3.onerror = function(event) {
              reject(event);
          };

          request3.onsuccess = function(event) {
              resolve(event.target.result);
          };

   })
}

// 调用
select(key,store).then(function(result){
    // success
    console.log(result)
}, function(e){
    // error
    console.log(e)
})

3.Event

// 监听自定义事件
window.addEventListener('selectSuccess', function(e){
   console.log(e.result)
})

function select(key,store, onsuccess) {
    var request3 = store.get(key);

      request3.onerror = function(event) {
          console.log("Error : " + event.errorCode);
      };
      request3.onsuccess = function(event) {
          // 触发事件
          var myEvent = new Event('selectSuccess');
          myEvent.result = event.target.result;
          window.dispatchEvent(myEvent);
      };
}
天蓬老师

有jquery的话,用$.Deferred方法

function select(key,store) {   // 怎么保证这个异步结果的返回...
    var request3 = store.get(key);
    var deferred = $.Deferred();

    request3.onerror = function(event) {
        console.log("Error : " + event.errorCode);
        deferred.reject("Error : " + event.errorCode);
    };

    request3.onsuccess = function(event) {
      deferred.resolve(event.target.result);
    };

    return deferred.promise();
  }

  select(key, store).then(function(result){
    // result
  });
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号