广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >uniapp高频面试题及答案合集
  • 458
分享到

uniapp高频面试题及答案合集

uniapp常见面试题uni-app面试题uniapp开发小程序面试题 2023-02-18 12:02:27 458人浏览 安东尼
摘要

目录谈谈你对uni-app的理解uni中如何为不同的平台设置不同的代码条件注释的作用和使用方法条件注释定义条件注释的语法uniapp中封装接口请求相较于微信小程序有什么要注意的uni

谈谈你对uni-app的理解

详情请点击此处

uni中如何为不同的平台设置不同的代码

使用条件注释

条件编译是用特殊的注释作为标记,在编译时根据这些特殊的注释,将注释里面的代码编译到不同平台。

条件注释的作用和使用方法

uni-app 已将常用的组件、js api 封装到框架中,开发者按照 uni-app 规范开发即可保证多平台兼容,大部分业务均可直接满足。

但每个平台有自己的一些特性,因此会存在一些无法跨平台的情况。

  • 大量写 if else,会造成代码执行性能低下和管理混乱。
  • 编译到不同的工程后二次修改,会让后续升级变的很麻烦。

在 C 语言中,通过 #ifdef、#ifndef 的方式,为 windowsMac 等不同 os 编译不同的代码。 uni-app 参考这个思路,为 uni-app 提供了条件编译手段,在一个工程里优雅的完成了平台个性化实现。

条件注释定义

条件编译是用特殊的注释作为标记,在编译时根据这些特殊的注释,将注释里面的代码编译到不同平台。

条件注释的语法

写法:以 #ifdef 或 #ifndef 加 %PLATFORM% 开头,以 #endif 结尾。

  • #ifdef:if defined 仅在某平台存在
  • #ifndef:if not defined 除了某平台均存在
  • %PLATFORM%:平台名称

uniapp中封装接口请求相较于微信小程序有什么要注意的

如果uniapp要在WEB端进行适配,要注意请求跨域问题---需要配置代理

uniapp中为什么会出现跨域问题,如何解决

原因

uniapp在web端进行适配时,会产生跨域问题

解决

配置代理

封装统一的http请求

针对于uni.request我们可以沿用之前我们在小程序中的封装思路,封装Http请求

封装的目的

  • 发送请求的时候调用更简洁
  • 添加一些通用的配置(超时时间,请求头)。 调用者没有传入配置的时候用默认的,调用者传入了相同,优先使用调用者
  • 改成使用promise解决异步问题
  • 统一维护域名
  • 添加请求拦截器,在所有请求之前加一些通用的操作
  • 代码响应之前,进行一些通用的操作 

封装代码 

const proxy = {
    "/api":{
             target:"http://59.111.104.104:8086",
             pathRewrite:'^/api'
    }
}
 
//http://59.111.104.104:8086/course
/// 作用: 根据当前的url和代理得到完整url
// 输入: 当前的url
// 输出: 完整的url
function getUrl(url){
    for(let key in proxy){
             if(url.startsWith(key)){
                        // 匹配到了代理
                       if(proxy[key].pathRewrite){
                                // 需要进行前缀重写
                                url = url.replace(new RegExp(proxy[key].pathRewrite),"")
 
                       }
                       url = proxy[key].target + url
                       break;
             }
    }
 
    ///返回处理后的url
    return url;
}
 
function getHeader(header={}){
    return {
                       "Content-Type":"application/x-www-fORM-urlencoded",
 
                       // #ifndef H5
                       "Cookie":uni.getStorageSync("cookie"),
 
                       // #endif
                       ...header
             }
}
 
function request(options){
    return new Promise((reslove,reject)=>{
             if(!options.header) options.header = {}
             const header = getHeader(options.header);
 
             // 请求之前进行一些操作
 
             // 加载代理
 
             // #ifndef H5
             options.url = getUrl(options.url)
 
             // #endif
             console.log(options.url)
             uni.request({
                       // 设置超时时间10s
                       timeout:10000,
                       ...options,
                       header,
                       success(res) {
                                // 响应之前进行一些操作
                                reslove(res)
                       },
                       fail(err) {
                                reject(err)
                       }
             })
    })
}
 
export function get(url,options){
    return request({
             url,
             ...options,
             method:"GET"
    })
}
 
export function post(url,data,options){
    return request({
             url,
             data,
             ...options,
             method:"POST"
    })
}
 
//配置代理

//Vue.config.js
module.exports = {
    devServer: {
             proxy: {
                       "/api": {
                                "target": "https://wk.myhope365.com",
                                "pathRewrite": {
                                          "^/api": ""
                                }
                       }
             }
    }
}

总结

到此这篇关于uniapp高频面试题及答案的文章就介绍到这了,更多相关uniapp高频面试题内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: uniapp高频面试题及答案合集

本文链接: https://www.lsjlt.com/news/196682.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • uniapp高频面试题及答案合集
    目录谈谈你对uni-app的理解uni中如何为不同的平台设置不同的代码条件注释的作用和使用方法条件注释定义条件注释的语法uniapp中封装接口请求相较于微信小程序有什么要注意的uni...
    99+
    2023-02-18
    uniapp常见面试题 uni-app面试题 uniapp开发小程序面试题
  • uniApp常见面试题及答案(推荐!)
    目录1.一句话总的形容- -下uniapp与vue和微信小程序的异同点2. Uniapp 中配置tabbar的方式 3. Uniapp 中常见的组件(说几个即可)4. Un...
    99+
    2023-02-10
    uniapp的面试题 uniapp面试问题 uni-app常见面试题
  • 高频率Vue面试题汇总以及答案
    目录什么是三次握手?什么是四次挥手?(close触发)什么是VUEX?什么是同源----跨域?什么是Promise?什么是fexl布局?数据类型什么是深浅拷贝?什么是懒加载?什么是守...
    99+
    2023-02-21
    常见vue面试题 vuejs面试题及答案 vue面试题及答案
  • 高频率Vue面试题及答案有哪些
    这篇文章主要介绍“高频率Vue面试题及答案有哪些”,在日常操作中,相信很多人在高频率Vue面试题及答案有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”高频率Vue面试题及答案有哪些”的疑惑有所帮助!接下来...
    99+
    2023-07-05
  • web前端高频面试题及答案有哪些
    这篇文章主要介绍了web前端高频面试题及答案有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇web前端高频面试题及答案有哪些文章都会有所收获,下面我们一起来看看吧。1.vue双向数据绑定的原理?mvvm场景...
    99+
    2023-07-04
  • Java集合框架的面试题及答案有哪些
    这篇文章主要介绍“Java集合框架的面试题及答案有哪些”,在日常操作中,相信很多人在Java集合框架的面试题及答案有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java集合框架的面试题及答案有哪些”的疑...
    99+
    2023-06-17
  • php面试题及答案
    1 请输出下面代码执行结果 答案:1 复制 讲解:count(var)是用来统计数组或对象的元素个数的。当var是null或者空数组时,结果为0。如果var是普通变量,则返回1。正常情况下返回var中的元素或属性个数。 2 请说明ph...
    99+
    2023-09-10
    php 开发语言
  • (面试题)python面试题集锦-附答案
    1、一行代码实现1-100的和 sum_1_100 = sum(range(1, 101)) print(sum_1_100) # 5050 2、如何在一个函数内修改全局变量的值 a = 100 def foo(): gl...
    99+
    2023-01-30
    面试题 集锦 答案
  • Java集合面试问题和答案有哪些
    这篇文章主要讲解了“Java集合面试问题和答案有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java集合面试问题和答案有哪些”吧!1.Java集合框架是什么?说出一些集合框架的优点?每...
    99+
    2023-06-17
  • J2EE面试题集锦(附答案)
    一、基础问答   1.下面哪些类可以被继承    java.lang.Thread (T)   java.lang.Number (T)   java.lang.Double (F)   java.lang.Math (F)   java...
    99+
    2023-06-03
  • 百度php面试题及答案
    基础题: 1.表单中 get与post提交方法的区别 答:get是发送请求HTTP协议通过url参数传递进行接收,而post是实体数据,可以通过表单提交大量信息. session与cookie的区别 答:session:储存用户访问的全局唯...
    99+
    2023-10-01
    php 数据库 开发语言
  • PHP面试题汇总及答案
    PHP程序员经典面试问题 1、PHP的意思,它能干些什么 PHP是一个基于服务端来创建动态网站的脚本语言,您可以用PHP和HTML生成网站主页,英文的全称(Professional Home Pages) (1)WEB开发、实现订单、网络通...
    99+
    2023-08-31
    php 开发语言
  • php算法面试题及答案
    PHP的基础知识点 PHP中类的继承属于单继承,一个子类只能继承一个父类。可见性为public protected的属性和方法可以被继承。 继承的方法或属性可以被重写,可见性越来越大。 PHP中的变量名区分大小写,但类名、函数名不区分大小...
    99+
    2023-08-31
    php 服务器 开发语言
  • java gc 面试题及答案(1~5题)
    1、既然有GC机制,为什么还会有内存泄露的情况理论上Java因为有垃圾回收机制(GC)不会存在内存泄露问题(这也是Java被广泛使用于服务器端编程的一个重要原因)。然而在实际开发中,可能会存在无用但可达的对象,这些对象不能被GC回收,因此也...
    99+
    2018-12-27
    java面试题 java
  • Python面试题及答案:12个 Python 程序员面试必备问题与答案
    这段时间很多伙伴问我有没有关于Python的面试题和答案,哈哈哈,7月确实也是面试跳槽的高峰哈!这两天总结了一下,这12个Python面试题和答案是必考的,给大家列了下来,认真看哈!...
    99+
    2023-06-02
  • C#经典面试题及答案 (3)
    13:大概描述一下ASP。NET服务器控件的生命周期 答:初始化 加载视图状态 处理回发数据 加载 发送回发更改通知 处理回发事件 预呈现 保存状态 呈现 处置 卸载 14:程序设计: 猫大叫一声,所有的老鼠都开始逃跑,主人被惊醒。(C#语...
    99+
    2023-01-31
    面试题 答案 经典
  • Python有哪些面试题及答案
    本篇内容主要讲解“Python有哪些面试题及答案”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python有哪些面试题及答案”吧!Q1、Python中的列表和元组有什么区别?Q2、Python的...
    99+
    2023-07-02
  • SQL有哪些面试题及答案
    本篇内容主要讲解“SQL有哪些面试题及答案”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL有哪些面试题及答案”吧!到此,相信大家对“SQL有哪些面试题及答案...
    99+
    2022-10-19
  • Dubbo面试题及答案有哪些
    本篇内容介绍了“Dubbo面试题及答案有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  1、Dubbo是什么  Dubbo是一个分布式...
    99+
    2023-06-04
  • PHP有哪些面试题及答案
    今天小编给大家分享一下PHP有哪些面试题及答案的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、什么事面向对象?主要特征是什...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作