多端兼容配置

标签

<!-- 一般标签 -->
body ———— page
div,ul, li, table,tr,td ———— view
span,b,i,font ———— text
a ———— navigator
img ———— image

js对象

APP和小程序无 document、xmlhttp、cookie、window、location、navigator、localstorage、websql、indexdb、webgl

对于基于js对象的第三方库,JQuery也不支持

vue语法

v-html:小程序不支持

小程序语法

<!-- 不遵循vue语法 -->
<view id="item-{{id}}"></view>

处理跨域

  1. egg-cors

    // 安装egg-cors包
    npm i egg-cors --save // 在plugin.js中设置开启cors
    exports.cors = {
    enable: true,
    package: 'egg-cors',
    }; // 在config.default.js中配置
    config.security = {
    domainWhiteList: [ '前端网页托管的域名' ],
    };
  2. 配置webpack-dev-server代理

    // vue.config.js
    module.exports = {
    devServer: {
    proxy: {
    '/api': {
    target: 'https://api-remote.xxxx.com',
    pathRewrite: {
    '^/api': '/'
    }
    }
    },
    }
    }
    • mock

      文档: https://github.com/nuysoft/Mock/wiki

      借助mocker-apimockjs这两个工具,直接配置devServerbefore选项即可

      // vue.config.js
      const webpackApiMocker = require('mocker-api') module.exports = {
      devServer: {
      before (app) {
      webpackApiMocker(app, path.resolve('./mock/index.js'))
      }
      }
      } // mock/index.js
      const Mock = require('mockjs') const Random = Mock.Random
      const mock = Mock.mock const proxy = {
      'GET /api/user/list': mock({
      'array|3': [
      {
      id: 1,
      username: 'kenny',
      sex: 'male'
      }
      ]
      }),
      'POST /api/login/account': (req, res) => {
      return res.json({
      status: 'ok',
      data: {
      id: Random.id(),
      userName: Random.cname(),
      city: Random.city()
      }
      })
      }
      } module.exports = proxy
    • public-path

      // 1. 将`publicPath`这项配置拿出来单独放在一个配置文件中,比如`project-config.js`
      const projectName = 'xxx' // 当前工程名,此处自由发挥即可
      const isDev = isDev() // 是否为本地开发环境,此处自由发挥即可
      const CDN_HOST = process.env.CDN_HOST // build时指定的CDN域名
      const APP_ENV = process.env.APP_ENV // build时指定的自定义环境 module.exports = {
      publicPath: isDev
      ? '/'
      : `//${CDN_HOST}/static/${projectName}/${APP_ENV}/`,
      } // 2. 其次,我们fork了一版官方的uni-app源码,并对@dcloudio/vue-cli-plugin-uni/index.js做了点改动
      // @dcloudio/vue-cli-plugin-uni/index.js#L30
      // 获取本地的project-config配置
      module.exports = (api, options) => {
      const projectConfig = require(api.resolve('project-config')) Object.assign(options, {
      outputDir: process.env.UNI_OUTPUT_TMP_DIR || process.env.UNI_OUTPUT_DIR,
      assetsDir
      }, vueConfig, {
      // 重新对publicPath进行覆盖
      publicPath: process.env.NODE_ENV === 'production' ? projectConfig.publicPath : '/'
      })
      }
  3. uniapp推荐方式

    // manifest.json
    {
    "h5": {
    "devServer": {
    "proxy": {
    "/api": {
    "target": "https://api-remote.xxxx.com",
    "pathRewrite": {
    "^/api": "/"
    }
    }
    }
    }
    }
    }

UniApp学习-多端兼容 & 跨域的更多相关文章

  1. 学习笔记:AJAX 跨域问题

    学习笔记:AJAX 跨域问题 AJAX 跨域是浏览器的问题. 只要 xhr 请求,不同的域名就会出现 AJAX 跨域问题. JSONP 是一要简单方式,但是有很多弊端,需要修改服务端代码. JSONP ...

  2. php服务端允许跨域访问

    >>php服务端允许跨域访问<< >>同源策略和跨域解决方案<<

  3. asp.net core webapi 服务端配置跨域

    在前后端分离开发中服务端仅仅只为前端提供api接口,并且前后端往往单独部署,此时就会出现浏览器跨域问题.asp.net core提供了简单优雅的解决方案. 在startup文件的Configure添加 ...

  4. php 服务端允许跨域访问

    加上需要允许跨域访问,配置如下(一下配置内容前不允许有其他任何输出操作): //设置允许跨域的 请求源地址//方式一:header("Access-Control-Allow-Origin: ...

  5. Web前端学习笔记之前端跨域知识总结

    0x00 前言 相信每一个前端er对于跨域这两个字都不会陌生,在实际项目中应用也是比较多的.但跨域方法的多种多样实在让人目不暇接.老规矩,碰到这种情况,就只能自己总结一篇博客,作为记录. 0x01 什 ...

  6. PHP服务端支持跨域

    跨域 由于浏览器的同源策略,导致浏览器页面访问非同源(协议.域名.端口任一不同)服务器产生跨域问题! PHP服务端配置支持跨域: // 指定允许其他域名访问, * 表示全部域名 header('Acc ...

  7. proxyTable-后端代理-跨域请求数据

    config >>> index.js  配置 proxyTable: { '/api': { target:'https://api.jisuapi.com', // 你请求的第三 ...

  8. [django]django配合前端vue前后端联调,django服务端解决跨域(django-cors-headers)

    django内部csrf post提交数据解决 https://www.cnblogs.com/iiiiiher/articles/9164940.html 前端写了个页面,里面$.post发现403 ...

  9. nodejs设置服务端允许跨域

    //设置跨域访问 app.all('*', function(req, res, next) { res.header("Access-Control-Allow-Origin", ...

  10. 「Django」rest_framework学习系列-API访问跨域问题

    #以中间件方式解决API数据访问跨域问题1.API下新建文件夹下写PY文件a.引入内置类继承: from django.middleware.common import MiddlewareMixin ...

随机推荐

  1. BBS升级版

    BBS项目 项目的前期准备 1.django2.2 创建一个django目录 (需要配置环境变量和数据库) 'DIRS': [os.path.join(BASE_DIR, 'templates'), ...

  2. SQL中常用函数操作

    --在SQL SERVER中批量替换字符串的方法 update [Table] set [Field] = REPLACE([Field],'被替换的原内容','要替换的内容') update HBb ...

  3. 使用Dapr和.NET 6.0进行微服务实战:Dapr简介

    大家好,我是张飞洪,感谢您的阅读,我会不定期和你分享学习心得,希望我的文章能成为你成长路上的垫脚石,让我们一起精进. 本文是<使用Dapr和.NET 6.0进行微服务实战>的第2篇Dapr ...

  4. Crossplane - 比 Terraform 更先进的云基础架构管理平台?

    ️URL: https://crossplane.io/ Description: 将云基础架构和服务组成自定义平台 API 简介 在 11 月的 KCD 上海现场,听了一场阿里云的工程师关于他们自己 ...

  5. vue3+quasar+capacitor开发多平台项目,使用quasar改变主题背景

    quasar的样式和其他的框架修改不太一样,需要我们使用动态的方式来进行变更,一般来说有两种方案进行主题修改 方案一: 修改样式所需文档: 这里是样式修改的说明:https://quasar.dev/ ...

  6. 前端必备基础知识之--------原生JS发送Ajax请求

    原生JS发送Ajax请求 ajax({ type: 'POST', url: 'http://10.110.120.123:2222', // data: param, contentType: 'a ...

  7. Solon v2.0 大版本发布。提效率!降成本!

    一个高效的 Java 应用开发框架:更快.更小.更简单.不是 Spring,没有 Servlet,也无关 JavaEE:新兴独立的开放生态.主框架仅 0.1 MB. 150来个生态插件,覆盖各种不同的 ...

  8. 你知道CDN是干嘛的吗?

    theme: cyanosis 前言 几年前,我在浏览互联网时偶然发现了一个新的电子商务网站,注意到网站上的图片加载速度不快.我刷新了页面并重试了几次.终于,十秒钟后,我能够看到带有图像的渲染网页. ...

  9. Pytest插件pytest-assume多重断言

    Pytest插件pytest-assume多重断言 背景 import pytest def test_assume1(): assert 1 == 2 print('hello') assert 2 ...

  10. 前端-jQuery 查找标签 事件 Bootstrap页面框架

    1.查找标签 1.基本选择器: $('#d1'):id选择器 $('.c1'):class选择器 $('div'):标签选择器 2.组合选择器: $('div#d1'):查找id为d1的div标签 $ ...