js——异常

概念

程序中,因为语法的疏忽或其他原因而导致程序中途崩溃的情况,我们称之为异常。

每个异常在程序中都是作为对象而存在的

JavaScript内置异常类

1.ReferenceError:引用异常

        一般是使用了未定义的变量

2.SyntaxError:语法异常

        一般是指代码写错

3.TypeError:类型异常

        一般是值数据类型错误。比如参数类型不对

4.RangeError:范围异常

        错误的数组下标

5.URIError:地址异常

        子处理非法地址时出错,比如利用decodeURICompoent()来处理地址,地址中不允许有%,有则报URIError

处理异常(try-catch-finally)

语法

try{
    //可能会发生异常的代码
}catch(异常对象){
    //发生异常时会执行的代码,catch可以定义一个局部变量来接受当前的异常对象
}finally{
    //无论是否发生了异常 ,都会执行的代码
}

finally是可选的,一般在使用了硬盘资源(io)需要关闭使用的通道,才会用finally

不要把所有的代码都放到try里面,这样会导致程序过于集中,并且加大内存资源的消耗,一般是对局部的代码使用。

一般执行的顺序:try-catch-finally

主动抛出异常

概念:当程序执行到需要严格判断时,一般当不满足条件时,可以选择主动抛出异常

语法

throw new  异常类名('发生异常时的提示内容'); 

一般强业务逻辑时,会使用主动抛出异常。

自定义异常(ES6、ES5)

JavaScript内置异常并不能很好的满足业务需求。比如登录异常、注册异常等,利用自定义异常来解决

语法

class 自定义异常名 extends Error{
    constructor(message){
        super(message);
        this.name = "自定义异常名";
    }
}

自定义异常只能是主动抛出

es5实现自定义异常

自定义异常类名.prototype = new Error();
function 自定义异常类名(message){
    this.message = message;
    this.name ="自定义异常类名";
}

return在异常中的表现

无异常时,如果return在try里,会先保存要返回的数据,再去执行finally(如果有),执行之后就返回。

有异常时。返回catch里的return。

无论是否有异常,只要finally有return,那么执行的是finally里的return

异常对象的常见属性

name:发生异常的名字

message:发生异常的原因

stack:异常发生栈,会输出在那个位置发生了异常

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力回答你的问题。首先,获取用户位置需要在小程序中使用微信提供的API,具体步骤如下: 1. 引入API ``` // 在页面的JS文件中引入API const QQMapWX = require('../../utils/qqmap-wx-jssdk.min.js'); ``` 2. 初始化API ``` // 在页面的JS文件中初始化API const qqmapsdk = new QQMapWX({ key: '你的腾讯地图开发者密钥' }); ``` 3. 获取用户位置 ``` // 在页面的JS文件中获取用户位置 wx.getLocation({ type: 'gcj02', success(res) { const latitude = res.latitude; const longitude = res.longitude; qqmapsdk.reverseGeocoder({ location: { latitude, longitude }, success(res) { console.log(res); } }); }, fail(res) { console.log(res); } }); ``` 接下来是异常流处理的完整示例: ``` // 在页面的JS文件中引入API const QQMapWX = require('../../utils/qqmap-wx-jssdk.min.js'); // 在页面的JS文件中初始化API const qqmapsdk = new QQMapWX({ key: '你的腾讯地图开发者密钥' }); // 在页面的JS文件中获取用户位置 wx.getLocation({ type: 'gcj02', success(res) { const latitude = res.latitude; const longitude = res.longitude; qqmapsdk.reverseGeocoder({ location: { latitude, longitude }, success(res) { console.log(res); }, fail(res) { console.log(res); wx.showToast({ title: '获取位置失败', icon: 'none' }); } }); }, fail(res) { console.log(res); wx.showModal({ title: '提示', content: '获取位置失败,请检查是否开启定位权限', showCancel: false, confirmText: '知道了' }); } }); ``` 在这个示例中,我们通过`wx.getLocation`方法获取用户位置,并且使用`qqmapsdk.reverseGeocoder`方法将经纬度转换为详细地址信息。如果获取位置或转换地址信息失败,我们会使用`wx.showToast`或`wx.showModal`方法提醒用户。这就是异常流处理的完整示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值