Jsonp實踐 客戶端 + nodejs服務端(筆記用)

客戶端:javascript

<html>
  <body>
  <script>
    // jsonp請求的回調函數
    function getJsonpData(data) {
      Object.keys(data).forEach(key => {
        console.log(`${key}: ${data[key]}`);
        const div = document.createElement('div');
        div.innerHTML = data[key];
        document.body.appendChild(div);
      })
    }
  </script>
  <script type="text/javascript" src="http://localhost:5000/jsonpTest?callback=getJsonpData"></script>
</body>
</html>
 
nodejs服務端:
var express = require('express');
const app = express();
var server = app.get('/jsonpTest', (req, res) => {
  // 要返回的數據
  const data = {
    "name": "tom",
    "age": 24,
    "city": "guangzhou"
  }
  // 獲取請求中的回調函數名稱
  const callFn = req.query.callback;
  // 經過返回 cbFnName(JSON.stringify(data)) 觸發客戶端的回調函數執行
  res.send(`${callFn}(${JSON.stringify(data)})`);
});
server.listen(5000, () => {
console.log('server start!')
});
相關文章
相關標籤/搜索