V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
lisianthus
V2EX  ›  JavaScript

关于 fetch 的一个问题

  •  
  •   lisianthus · 2020-12-28 11:48:56 +08:00 · 2034 次点击
    这是一个创建于 1186 天前的主题,其中的信息可能已经有所发展或是发生改变。

    为什么第二种写法会报错:

    fetch('xxx').then(res => res.json());  //ok
    
    fetch('xxx').then(Response.prototype.json.call);  //TypeError: undefined is not a function
    

    如果把 fetch 返回的 Stream 对象打印出来,用 Store as global variable 保存到变量 temp1 是可以正常使用 Response.prototype.json.call 的:

    Response.prototype.json.call(temp1).then(console.log);  //ok
    
    第 1 条附言  ·  2020-12-28 12:54:11 +08:00

    问题已解决,需要给 call 绑定 this:

    fetch('xxx').then(Function.call.bind(Response.prototype.json));  //ok
    
    9 条回复    2020-12-29 14:23:46 +08:00
    bnrwnjyw
        1
    bnrwnjyw  
       2020-12-28 12:34:28 +08:00   ❤️ 1
    var a = Response.prototype.json.call
    console.log(a) // undefined

    这样懂么
    lisianthus
        2
    lisianthus  
    OP
       2020-12-28 12:39:48 +08:00
    @bnrwnjyw 变量 a 打印出来是 ƒ call() { [native code] } ,undefined 是 console.log 的返回值
    bnrwnjyw
        3
    bnrwnjyw  
       2020-12-28 12:42:36 +08:00   ❤️ 1
    @lisianthus 你调用一下 a 就知道了。
    lisianthus
        4
    lisianthus  
    OP
       2020-12-28 12:52:43 +08:00
    @bnrwnjyw 原来如此,需要给 call 绑定 this,这样就没问题了:fetch('xxx').then(Function.call.bind(Response.prototype.json))
    indev
        5
    indev  
       2020-12-28 13:23:46 +08:00
    这是可以继续执行 fetch 返回的函数吗?
    lisianthus
        6
    lisianthus  
    OP
       2020-12-28 14:28:05 +08:00
    @indev 没明白你问的是什么,fetch 返回的是 Promise,Promise 中 resolve 的值为 fetch 获取的流对象,then 接收一个回调函数作为参数,回调函数接收到的参数即为 resolve 的流对象,可以使用这个回调函数来处理流对象
    indev
        7
    indev  
       2020-12-28 14:37:26 +08:00
    @lisianthus 我是想问如果 resolve 后的 object 包含一个函数体,Function call 会执行这个函数吗? XSS 那种。
    lisianthus
        8
    lisianthus  
    OP
       2020-12-28 14:49:02 +08:00
    @indev 不会。这种写法等价于 (res) => res.xxx() ,只是把流对象解析成 xxx 格式而已,要执行函数的话使用 jsonp 才行吧。
    indev
        9
    indev  
       2020-12-29 14:23:46 +08:00
    @lisianthus 嗯,明白了,谢谢
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5456 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 79ms · UTC 09:08 · PVG 17:08 · LAX 02:08 · JFK 05:08
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.