首页 > 编程语言 >salesforce学习笔记(3-1)- JavaScript Promise(LWC)

salesforce学习笔记(3-1)- JavaScript Promise(LWC)

时间:2023-04-07 18:13:25浏览次数:66  
标签:salesforce console log apex JavaScript Promise result error

在JS代码中,Promise到底有什么作用?

首先,我们知道的是,Javascript是单线程的,什么意思呢?就是说JS在同一时间只能做一个操作,代码的执行是一行一行进行的:

 

 

这种执行方式带来的问题就是在我们打开某个画面的时候,画面可能会卡住转圈、加载中状态很久,用户体验感很差。

Promise可用于资源加载或异步操作,于是,用Promise方法便能解决这个问题。

以下,是使用Promise的方法例图:

 

 

 上图对应代码如下:

 1 let shouldBeResolve = true; 
 2 
 3 const promise = new Promise((resolve, reject) => {
 4   setTimeout(() => {
 5       if (shouldBeResolve) {
 6           resolve('success!');
 7       }
 8 
 9       reject('failed!');
10   }, 1000);
11 });
12 
13 // then/catch
14 const thenCatchApproach = () => {
15   promise
16     .then((result) => {
17       console.log(`thenCatchApproach result => ${result}.`);
18     })
19     .catch((error) => {
20       console.log(`thenCatchApproach error => ${error}.`);
21     })
22     .finally(() => {
23       console.log('thenCatchApproach done.');
24     })
25 }
26 
27 // async/await
28 const asyncAwaitApproach = async () => {
29   try {
30     const result = await promise;
31     console.log(`asyncAwaitApproach result => ${result}.`);
32   } catch (error) {
33     console.error(error);
34     console.log(`asyncAwaitApproach error => ${error}.`);
35   } finally {
36     console.log('asyncAwaitApproach done.');
37   }
38 }
39 
40 // success
41 shouldBeResolve = true;
42 
43 thenCatchApproach();
44 asyncAwaitApproach();

Promise主要有以下三种状态:

  • pending: 初始状态
  • fulfilled: 意味着操作执行成功
  • rejected: 意味着操作失败

同时,由上图可看出,then/catchasync/await非常相似,都可以用来解决Promise问题。

那么,两者有什么区别呢?

使用async/await将暂停函数执行,直到Promise有结果(resolve或者reject)。因此,此异步行为表现得有点像同步。

 1 function myPromiseFunction() {
 2     return new Promise((resolve, reject) => {
 3         setTimeout(() => {
 4             resolve('Success');
 5         }, 2000);
 6     });
 7 }
 8 
 9 (async () => {
10     console.log('Start');
11     const result = await myPromiseFunction();
12     console.log(`result - ${result}`);
13     console.log('End');
14 })();

而then/catch则是将继续执行逻辑,直到Promise有结果JS将会执行then()方法回调。

 1 function myPromiseFunction() {
 2     return new Promise((resolve, reject) => {
 3         setTimeout(() => {
 4             resolve('Success');
 5         }, 2000);
 6     });
 7 }
 8 
 9 (() => {
10     console.log('Start');
11     myPromiseFunction()
12         .then(result => {
13             console.log(`result - ${result}`);
14         })
15         .catch(error => {
16             console.error(error);
17         })
18     console.log('End');
19 })();

接下来,就是在LWC中,Promise的使用情况了。

在LWC中,所有的Apex方法都返回一个Promise对象。

 1 import apexMethodName from '@salesforce/apex/Namespace.Classname.apexMethodReference'; 

我们可以通过三种方式使用上述apex方法:

  • @wire
  • Then/Catch
  • Async/Await

Wire

使用场景:

  • 返回的数据结果可以被缓存,@wire的apex方法需要被标记为(Cacheable=true)
  • @wire只可以用来读取数据,不支持DML操作(insert,update,delete)

对于一个属性:

1 import apexMethodName from '@salesforce/apex/Namespace.Classname.apexMethodReference';
2 
3 @wire(apexMethodName, { apexMethodParams })
4 property;

对于一个方法:

 1 import apexMethodName from '@salesforce/apex/Namespace.Classname.apexMethodReference';
 2 
 3 @wire(apexMethodName, { apexMethodParams })
 4 wiredFunction({ error, data }) {
 5     if (data) {
 6         console.log(data);
 7     } else if (error) {
 8         console.error(error);
 9     }
10 }

Then/Catch

使用场景:

  • 需要对数据库进行DML操作(insert,update,delete)
  • 数据不能被缓存
  • 应该用户操作(如onclick事件)后调用该apex方法
 1 mport apexMethodName from '@salesforce/apex/Namespace.Classname.apexMethodReference';
 2 
 3 apexMethodName
 4     .then(result => {
 5         console.log(result);
 6     })
 7     .catch(error => {
 8         console.error(error);
 9     })
10     .finally(() => {
11         console.log('done.'); //good place to hide spinner
12     })

Async/Await

使用场景:

  • 需要对数据库进行DML操作(insert,update,delete)
  • 数据不能被缓存
  • 应该用户操作(如onclick事件)后调用该apex方法
  • 代码应该表现为同步
1 import apexMethodName from '@salesforce/apex/Namespace.Classname.apexMethodReference';
2 
3 try {
4     let result = await apexMethodName;
5 } catch (error) {
6     console.error(error);
7 } finally {
8     console.log('done.'); //good place to hide spinner
9 }

多个await链式执行

 1 import { LightningElement } from 'lwc';
 2 
 3 import apexMethod1 from '@salesforce/apex/ClassName.apexMethod1';
 4 import apexMethod2 from '@salesforce/apex/ClassName.apexMethod2';
 5 import apexMethod3 from '@salesforce/apex/ClassName.apexMethod3';
 6 
 7 export default class LwcPromise extends LightningElement {
 8 
 9     connectedCallback() {
10         this.invokeApexMethods();
11     }
12 
13     async invokeApexMethods() {
14         try {
15             const result1 = await apexMethod1();
16             const result2 = await apexMethod2({ param: result1 });
17             const result3 = await apexMethod3({ param: result2 });
18         } catch(error) {
19             console.error(error);
20         } finally {
21             console.log('Finally Block');
22         }
23     }
24 }

Async/Await总结:

异步方法总会返回一个Promise对象。Await只能被用在被标记为async(异步)的方法里。

 

欢迎评论转发,如文中有问题欢迎指正!

Copyright © 乔木船长

博客主页:https://www.cnblogs.com/captainqiaomu/

 

标签:salesforce,console,log,apex,JavaScript,Promise,result,error
From: https://www.cnblogs.com/captainqiaomu/p/17297012.html

相关文章

  • javascript把本地sql数据库表转换为对象
    在做项目的时候,需要读取本地数据库,并且在页面上显示出来,原始数据读取出来的原始数据如下:varr=sqliteDB.exec(document.getElementById('txtSQL').value); console.info(r);  使用系统的转换方式console.log('Hereisarow:'+JSON.stringify(r));  可以看到其......
  • 你不会还不知道JavaScript常用的8大设计模式?
    JavaScript常用的8大设计模式有工厂模式:工厂模式是一种创建对象的模式,可以通过一个共同的接口创建不同类型的对象,隐藏了对象的创建过程。单例模式:单例模式是一种只允许实例化一次的对象模式,可以通过一个全局访问点来访问它。建造者模式:建造者模式是一种创建复杂对象的模式,通......
  • Promise
    目录Promise及其应用promise与异步编程的关系promise的作用与用法静态方法实例方法实际环境应用Promise总结async函数await参考Promise及其应用promise与异步编程的关系promise是异步编程的一种解决方案,可以将异步对象和回调函数脱离开来,通过then方法在这个异步操......
  • C# javascript中调用自定义函数function
    Default.aspx1<script>2//自定义函数3functionpageInit(){4letdata=[];5varsource_data=my_source_data2();//my_source_data2是一般程序Handler.ashx中,自定义的方法6varmy_data=source_data.split('###');......
  • JavaScript ES6中class的用法
    实例代码如下classPerson{constructor(name){if(!arguments.length){console.log("我是个人")}else{console.log(`我是${name}`)}}......
  • javascript实现代码高亮
    9款有用的Javascript代码高亮脚本 语法突出显示非常重要,尤其是当我们想在博客上展示我们的代码示例时。通过在博客上启用语法突出显示,读者可以更轻松地阅读代码块。 我们周围有很多免费且有用的语法突出显示脚本。大多数脚本都是使用Javascript编写的,尽管其中一些脚本由其他编程......
  • JavaScript超大文件上传解决方案:分片断点上传(一)
    ​ 前段时间做视频上传业务,通过网页上传视频到服务器。视频大小小则几十M,大则1G+,以一般的HTTP请求发送数据的方式的话,会遇到的问题:1,文件过大,超出服务端的请求大小限制;2,请求时间过长,请求超时;3,传输中断,必须重新上传导致前功尽弃; 解决方案:1,修改服务端上传的限制配置;Nginx以......
  • Vue进阶(四十五):精解 ES6 Promise 用法
    一、前言复杂难懂概念先不讲,我们先简单粗暴地把Promise用一下,有个直观感受。那么第一个问题来了,Promise是什么呢?是类?对象?数组?函数?别猜了,console.dir(Promise)直接打印出来看看。这么一看就明白了,Promise是一个构造函数,自己身上有all、reject、resolve这几个眼熟的方法,原型上有th......
  • Javascript中扁平化数据结构与JSON树形结构转换详解
    Javascript中扁平化数据结构与JSON树形结构转换详解原文链接:https://www.jb51.net/article/247525.htm+目录一.先说简单的树形结构数扁平化处理二.再讲将扁平化数据结构转JSON树状形结构扩充一个知识点:forin与forof的区别:总结不废话,直接开干一.先说简单的树形结构数......
  • 方法定义,Date和JSON对象,及JavaScript式面向对象编程
    一.方法1.方法的定义 方法就是把函数放在对象里面,对象有两个东西:属性和方法通过对象名.方法名()使用a.第一种方法定义<script>varsetFun={name:"maming",birth:2002,//方法:被包含在对象之中age:function(){varnow=ne......