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

用简单的 demo 学习各种跨域

  •  
  •   xuhaodong66 · 2018-01-16 17:38:17 +08:00 · 2691 次点击
    这是一个创建于 2503 天前的主题,其中的信息可能已经有所发展或是发生改变。

    前言

    因为学习跨域需要配置本地服务器,可能会比较麻烦,所以自己根据网上的博客写了大多数跨域的简单 demo,可以自己在本地运行,而且不用配置服务器。自己对于跨域的理解刚开始也仅仅在于网上的博客文章,通过写这些可以本地运行的 demo 让我对跨域有了更直面的理解,希望这些 demo 对你们有帮助,有错误的话欢迎指正,欢迎 PR。

    github 地址: https://github.com/FatDong1/cross-domain

    多种跨域 demo

    • CROS 跨域

    • JSONP 跨域

    • postMessage 跨域,html5 新 API

    • window.name 跨域

    • location.hash 跨域

    • document.domain 跨域

    • 后端 proxy 代理跨域

      • demo1,通过使用 http-proxy-middleware 插件设置后端的代理

      • demo2,不使用插件去配置代理,更加原生地解释了 proxy 跨域的原理

    • websocket 跨域

    优点

    • 通过本地运行 demo,可以快速理解多种跨域。

    • demo 简单易懂,内附许多注释。

    • 学习门槛低。

    原理

    通过 nodeJS 的 express 框架在 3000 端口和 3001 端口分别生成服务器,在 3000 端口和 3001 端口进行跨域访问。

    学习建议

    在学习其中一种跨域方法的时候,建议边运行项目里的 demo,边在网上搜索博客文章学习这种跨域方法,这样有助于快速并且深入理解跨域。鉴于网上有很多文章详细讲述跨域知识,只是少了可以本地运行的 demo,所以这里就不再赘述跨域知识。

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   913 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 21:47 · PVG 05:47 · LAX 13:47 · JFK 16:47
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.