fetch-polyfill2

WebJar for fetch-polyfill2

License

License

MIT
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

fetch-polyfill2
Last Version

Last Version

0.0.3
Release Date

Release Date

Type

Type

jar
Description

Description

fetch-polyfill2
WebJar for fetch-polyfill2
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/RubyLouvre/fetch-polyfill

Download fetch-polyfill2

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/fetch-polyfill2/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>fetch-polyfill2</artifactId>
    <version>0.0.3</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/fetch-polyfill2/
implementation 'org.webjars.npm:fetch-polyfill2:0.0.3'
// https://jarcasting.com/artifacts/org.webjars.npm/fetch-polyfill2/
implementation ("org.webjars.npm:fetch-polyfill2:0.0.3")
'org.webjars.npm:fetch-polyfill2:jar:0.0.3'
<dependency org="org.webjars.npm" name="fetch-polyfill2" rev="0.0.3">
  <artifact name="fetch-polyfill2" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='fetch-polyfill2', version='0.0.3')
)
libraryDependencies += "org.webjars.npm" % "fetch-polyfill2" % "0.0.3"
[org.webjars.npm/fetch-polyfill2 "0.0.3"]

Dependencies

There are no dependencies for this project. It is a standalone project that does not depend on any other jars.

Project Modules

There are no modules declared in this project.

fetch-polyfill

fetch polyfill which supports all mainstream browsers, even IE6, IE7, IE8.....

$ npm install fetch-polyfill2 --save
$ npm install bluebird -- save
$ npm install json3 -- save

HTML

<script src='path-to-node_modules/bulebird/bluebird.js' ></script>
<!--or other promise polyfill library-->
<script src='path-to-node_modules/json3/json3.js' ></script>
<script src='path-to-node_modules/fetch-polyfill2/dist/index.js' ></script>
<script>
fetch('/users.html')
  .then(function(response) {
    return response.text()
  }).then(function(body) {
    document.body.innerHTML = body
  })
</script>

It is strongly recommended that these three libraries be packaged together with webpack

JSON

fetch('/users.json')
  .then(function(response) {
    return response.json()
  }).then(function(json) {
    console.log('parsed json', json)
  }).catch(function(ex) {
    console.log('parsing failed', ex)
  })

Response metadata

fetch('/users.json').then(function(response) {
  console.log(response.headers.get('Content-Type'))
  console.log(response.headers.get('Date'))
  console.log(response.status)
  console.log(response.statusText)
})

Post form

var form = document.querySelector('form')

fetch('/users', {
  method: 'POST',
  body: new FormData(form)
})

Post JSON

fetch('/users', {
  method: 'POST',
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    name: 'Hubot',
    login: 'hubot',
  })
})

File upload

var input = document.querySelector('input[type="file"]')

var data = new FormData()
data.append('file', input.files[0])
data.append('user', 'hubot')

fetch('/avatars', {
  method: 'POST',
  body: data
})

###IE6-7 cors

涉及到的参数

jsonpCallbackFunction :  后端生成的函数名, 不传自动生成,与jQuery一致 jsonpCallback: 链接中的名字,不传为callback,与jQuery一致 charset: 设置script的字符集

所有情况下,想跨域,都需要手动设置 credentials: 'include' 所有情况下,如果想发送请求,想带着cookie, 都需要设置 credentials: 'include'

fetch('/users', { //jsonp!!!
  credentials: 'include',
}).then(function(response){
   return response.json()
}).then(function(){

})

###使用fetch下载HTML乱码问题

fetch('http://tieba.baidu.com')
    .then(res=> res.blob())
    .then(blob => {
        var reader = new FileReader();
        reader.onload = function(e) {
          var text = reader.result;
          console.log(text)
        }
        reader.readAsText(blob, 'GBK') //或 UTF8,逐个试
    })

更多用法见这里 http://www.w3ctech.com/topic/854

Versions

Version
0.0.3