- 经验笔记:Node.js 中的 process.nextTick
漆黑的莫莫
笔记node.js
Node.js中的process.nextTick经验笔记引言在Node.js环境中,process.nextTick是一个非常重要的API,用于在当前执行栈的所有同步操作完成后立即执行一个回调函数。这使得开发者能够在异步I/O操作和其他异步事件之前,执行一些需要立即响应的任务。本文将探讨process.nextTick的工作原理、使用场景以及注意事项。process.nextTick的工作机制N
- Vue 中 nextTick 的最主要作用是什么,为什么要有这个 API
m0_73882020
vue.jsjavascriptecmascript
在Vue.js中,nextTick是一个用于在DOM更新后执行代码的API。它的主要作用是确保在某个操作完成后,DOM已经更新且可以被访问或操作。这个API在处理需要等待DOM更新完成的逻辑时非常有用。nextTick的最主要作用确保DOM更新完成:Vue的响应式系统会在数据变化后异步更新DOM。当你更改数据并立即访问DOM时,可能会发现DOM尚未反映最新的变化。nextTick允许你在DOM更新
- js(vue)如何实现页面截图,向后端传递,生成PDF
R-sz
vue.jsjavascript前端
利用htmm12canvas首先引入npminstallexpressmulter#或者yarnaddexpressmulter代码如下:-->中间代码省略import{nextTick,ref,provide}from"vue";import{useGetResizeBodySize}from'@/hooks/useGetScaleHeight'importEquConsumeSpareRank
- 【面试题系列Vue04】Vue.js中 $nextTick 原理及作用
周三有雨
面试题vuevue.js前端javascript
作用:$nextTick主要用于延迟执行某个函数,直到下一次DOM更新循环结束之后。这通常在你修改了一些数据,并且想要等待Vue完成DOM的重新渲染后,才执行依赖于新DOM的操作时使用。常见的使用场景包括:在DOM更新后执行DOM依赖的操作,如操作滚动位置、聚焦输入框、或是基于新布局的计算。在进行了一系列数据更新后,确保所有的DOM变更都已完成。原理:Vue.js使用异步队列的方式来处理DOM更新
- v-masonry踩坑 数据不重绘问题
黎明寄波澜*
javascript前端vue.js
在一堆数据中数据发生改变但是页面没有发生重绘(nextTick)描述场景我的小组里边有很多数据但是当我退出小组回来之后瀑布流出现空白情况请看图通过查看文档发现$redrawVueMasonry可以实现重绘于是各种调用不生效,最后发现把他写在nextTick里边才生效有当数据发生改变之后!!!请求完毕之后再去调用方法才有用所以从watch里边进行监听getCurrentInstance是vue里边的
- vue3+element-plus实现table表格整列的拖拽
不恰香菜辣baga
vue.jselementui
参考文章:https://blog.csdn.net/candy0521/article/details/136470284一、为防止原文章不见了将参考文章代码拷过来了(不好意思):这是参考文章的代码可直接复制粘贴运行import{nextTick,onMounted,reactive,ref}from"vue";importSortablefrom'sortablejs';consttableD
- vue如何获取div的宽度_vue 动态获取div宽高有时候为0的情况
weixin_39801613
vue如何获取div的宽度
项目背景:需要使用echarts进行图表展示。由于div宽高是不固定的,因此需要先获取父级的宽高再把值赋予到图表的div中。需要使用this.$nextTick(()=>{});方法,在mounted中,保证DOM渲染完全后,在进行echarts初始化。importechartsfrom'echarts';exportdefault{name:"wifiCollect",props:{classN
- 基于vue3和audio封装的简易音频播放器
九号窗口
音视频javascriptvue.js
样式如图所示{{fileName}}{{transTime(audioCurrent)}}{{transTime(audioDuration)}}import{ref,onBeforeMount,onUnmounted,onMounted,watch,nextTick}from'vue';constprops=defineProps({//音频地址url:{type:String,required
- Vue项目-Table添加Form表单校验
呆呆的小草
Vuevue.jselementuijavascript
一、HTML新增表格数据{{row.name}}{{row.age}}{{row.sex}}删除任务信息生成二、JS//------------------->-------------------import{ref,reactive,onMounted,nextTick}from"vue";import{ElMessage}from"element-plus";//--------------
- resetFields()失效
虾仁不眨眼ok
前端javascripthtmlvue
问题描述先点击新增,再取消弹窗。resetFields()正常运行,清空表单内容。先点击编辑,再新增,表单内容不能清空。解决方法在nextTick里赋值表单内容,因为弹窗会把第一次赋值的内容当成初始值,所以要在弹窗加载完之后再赋值constopenModal=(data)=>{base.visible=true;nextTick(()=>{base.formData=Object.assign({
- vue3+element-plus el-input 自动获取焦点
Hico、
vue.js前端elementui
虽然element有提供input的autofocus属性,但是当我们第二次进入页面就会发现autofocus已经不再生效,需要通过onMounted去触发input的focus解决这个问题。1.先给el-input绑定一个ref:2.定义一个函数去触发这个input的focus:constfocusInput=()=>{nextTick(()=>{inputRef.value.focus()})
- uniapp:APP端webview拦截H5页面跳转,华为市场发布需要限制webview的H5页面跳转
Mosowe
uni-app
在使用uniapp开发APP项目时,华为市场上线APP会被打回来:您的应用内容存在点击跳转至第三方应用市场或游戏中心下载渠道的问题,不符合华为应用市场审核标准。华为审核指南4.6因此可以考虑下面的处理方式,通过拦截webview页面的url实现:onReady(()=>{nextTick(()=>{plusReady();});});constplusReady=()=>{letpages=get
- 10 分钟了解 nextTick ,并实现简易版的 nextTick
秋の本名
程序员前端vue.js前端javascript
前言在Vue.js中,有一个特殊的方法nextTick,它在DOM更新后执行一段代码,起到等待DOM绘制完成的作用。本文会详细介绍nextTick的原理和使用方法,并实现一个简易版的nextTick,加深对它的理解。一.什么是nextTick简单的说,nextTick方法是在Vue.js中常见的一种异步更新DOM的机制。它的原理是利用JavaScript的事件循环机制以及浏览器的渲染流程来实现延迟
- vue3导入文件夹、导入文件、导出zip、导出
摇头的金丝猴
vuevue.jsjavascript前端
记录一下之前项目用到的导入文件夹和导入文件出现的一些注意的点,直接上代码注意:在传相同的文件时,会发现无法触发change事件nextTick(()=>{planFileRef.value.value="";planWordRef.value.value="";});上传文件夹上传文件import{ref}from"vue";letplanFileRef=ref();letplanWordRef=
- [uniapp生命周期]详细讲解uniapp中那些属于vue生命周期,那些属于uniapp独有的生命周期,以及这中间的区别 相关的内容和api 代码注释
门前大桥下.
uniappvue.jsuni-app前端
目录1.Vue.js生命周期函数2.Vue生命周期函数代码beforeCreatecreatedbeforeMountmountedbeforeUpdateupdatedbeforeDestroydestroyed$nextTick$forceUpdate$destroy3.UniApp独有的生命周期函数onLaunchonShowonHideonError4.总结在UniApp中,除了Vue.j
- Vue性能「十九」-- Vue常见优化方式 ***
loushumei
合理使用v-show和v-if合理使用computed(缓存)v-for中加key,避免和v-if同时使用自定义事件和DOM事件及时销毁(否则会导致内存泄露)合理使用异步组件(import)合理使用缓存组件(keep-alive)合理使用异步渲染($nextTick)data层级不要太深(导致深度监听时递归的次数比较多)使用vue-loader在开发环境做模板编译(预编译)使用SSR(服务端渲染)
- 1000字带你掌握nextTick背后的原理
m0_70273331
Web前端经验分享前端前端框架
答:如果我们需要获取数据更新后的dom信息,比如动态获取dom的宽高、位置等,就需要使用nextTick。handleClick(){this.msg=‘helloworld’;this.$nextTick(()=>{console.log(this.$refs.message.innerText)//helloworld})}如vue官网的描述:Vue在更新DOM时是异步执行的。只要侦听到数据变
- VUE 生成二维码插件qrcodejs2踩的坑
老街老街
使用步骤:1.安装qrcodejs2(注意:安装的是qrcodejs2,不要安装qrcode--->会报错)npminstallqrcodejs2--save2.页面引入image.png3。注意引入的时候://注意:在需要调用的地方这样必须这样调用否则会出现appendChildnull就是id为qrcode的dom获取不到返回结果为nullthis.$nextTick(function(){t
- vue element-ui table 对获取的数据进行toggleRowSelection
小狼在IT
data(){return{Detail:[]}}methods:{get_Detail(){letgetDetail=[]//获取的数据this.Detail=getDetaillet_this=this//必须要在$nextTick里面执行,否则toggleRowSelection无效_this.$nextTick(function(){_this.$refs.DetailTable.togg
- $nextTick
林键燃
$nextTick就是用来知道什么时候DOM更新完成异步更新队列(重要概念)Vue在观察到数据变化时并不是直接更新DOM,而是开启一个队列,并缓冲在同一事件循环中发生的所有数据改变。在缓冲时会去除重复数据,从而避免不必要的计算和DOM操作。然后,在下一个事件循环tick中,Vue刷新队列并执行实际(已去重的)工作。语法this.$nextTick(callback)callback函数中完成我们操
- 一道经典的异步试题
华子Code1024
javascript前端面试
JavaScript任务可以分为同步任务和异步任务异步任务:微任务和宏任务微任务:Promise回调:当一个异步操作通过`newPromise`函数执行并返回后,可以注册一个回调函数以在异步操作完成时被调用。Node.js中process.nextTick:这是一个在Node.js中用于运行微任务的机制。MutationObserver对DOM变更的监听:这个API可以用来监听文档中元素的属性或子
- vue 一键复制文本
欧小肥OuO
handleCopy(val){this.$axios.get('后台路径',{params:{mdjid:val.mdjid,jdid:val.jdid}}).then(rs=>{if(rs){this.$nextTick().then(()=>{this.copyText(rs)})}})},copyText(data){leturl=dataletoninput=document.creat
- vue中什么时候使用$nextTick
得知此事须躬行
vue前端开发vue
vue的dom元素渲染是异步的,有的场景中在页面元素还没渲染就执行了需渲染后才执行的代码,就会报错,那么只要在this.$nextTick中执行该代码即可解决报错的问题。this.$nextTick(()=>{//要执行的代码})
- vue的nextTick的作用
阿里超级工程师
H5移动开发
很多人不明白,vue的nextTick是干什么用的。要理解nextTick,就要理解dom,nextTick是解决dom没有渲染的时候,无法做一些操作,我们想在dom完成后执行的。比如你有一个标签用了然后你有一个函数设置了this.showComp=true这个时候假如你使用this.$refs.mycomp去获取组件,获取的是空值,因为刚才showComp还是false,刚刚才设置成true,d
- vue中的this.$nextTick和Vue.nextTick
tenro
首先this.$nextTick其实就是Vue.nextTick,因为this指向的就是Vue官方说法:在下次DOM更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的DOM。(似乎有点云里雾里)普及一下异步执行的运行机制如下:(1)所有同步任务都在主线程上执行,形成一个执行栈(executioncontextstack)。(2)主线程之外,还存在一个"任务队列"(taskq
- 3分钟带你了解Vue3的nextTick()
_Minato_
vue.js前端javascripthtml前端框架es6css3
前言Vue实现响应式并不是数据发生变化之后DOM立即变化,而是按一定的策略进行DOM的更新。简单来说,Vue在修改数据后,视图不会立刻更新,而是等同一事件循环中的所有数据变化完成之后,再统一进行视图更新,nextTick()方法就会在这样的DOM更新循环结束后调用指定的函数。概念在Vue3中nextTick()方法的行为和Vue2中基本相似,但它进行了一些优化,以提高性能和稳定性。nextTick
- 使用canvas根据坐标集合绘制坐标点 + 更改坐标轴 + 旋转y轴
王拾羽
javascript前端开发语言
效果场景根据坐标点使用canvas在画布上展示出来html浏览器版本过低,请去下载最新版本浏览器data数据coordinates:[{x:100,y:50,},{x:100,y:-50,},{x:-50,y:50,},{x:-50,y:-50,},],绘制created(){this.$nextTick(()=>{this.canvas=this.$refs.canvasImg;this.ctx
- Ant Design Vue上传多个图片
ᥬ 小月亮
UI框架vue.js前端javascript
模板代码:定义变量:文件限制的函数:上传的函数:样式函数:完整代码:上传图片tab:tab1:确定取消import{defineComponent,reactive,toRefs,watch,nextTick}from'vue'import{message}from'ant-design-vue'importGfrom'@/request/G'importaxiosfrom'axios'expor
- Vue Error in nextTick: "RangeError: Maximum call stack size exceeded"
Marissa_z
报错问题如下:ErrorinnextTick:"RangeError:Maximumcallstacksizeexceeded",经过一系列的问题查询,发现问题所在,原来两个组件的name重复了!!!修改组件名就OK了!exportdefault{name:"main-table",}
- useEcharts更加方便的使用echarts,echarts动态尺寸,
Time202051
echartsvue3
import{ref,unref,nextTick,onMounted}from"vue";importemptyfrom"@/assets/image/public/empty.png";importtype{Ref}from"vue";importechartsfrom"@/libs/echarts";//import{EChartsOption}from"echarts";import{us
- 多线程编程之存钱与取钱
周凡杨
javathread多线程存钱取钱
生活费问题是这样的:学生每月都需要生活费,家长一次预存一段时间的生活费,家长和学生使用统一的一个帐号,在学生每次取帐号中一部分钱,直到帐号中没钱时 通知家长存钱,而家长看到帐户还有钱则不存钱,直到帐户没钱时才存钱。
问题分析:首先问题中有三个实体,学生、家长、银行账户,所以设计程序时就要设计三个类。其中银行账户只有一个,学生和家长操作的是同一个银行账户,学生的行为是
- java中数组与List相互转换的方法
征客丶
JavaScriptjavajsonp
1.List转换成为数组。(这里的List是实体是ArrayList)
调用ArrayList的toArray方法。
toArray
public T[] toArray(T[] a)返回一个按照正确的顺序包含此列表中所有元素的数组;返回数组的运行时类型就是指定数组的运行时类型。如果列表能放入指定的数组,则返回放入此列表元素的数组。否则,将根据指定数组的运行时类型和此列表的大小分
- Shell 流程控制
daizj
流程控制if elsewhilecaseshell
Shell 流程控制
和Java、PHP等语言不一样,sh的流程控制不可为空,如(以下为PHP流程控制写法):
<?php
if(isset($_GET["q"])){
search(q);}else{// 不做任何事情}
在sh/bash里可不能这么写,如果else分支没有语句执行,就不要写这个else,就像这样 if else if
if 语句语
- Linux服务器新手操作之二
周凡杨
Linux 简单 操作
1.利用关键字搜寻Man Pages man -k keyword 其中-k 是选项,keyword是要搜寻的关键字 如果现在想使用whoami命令,但是只记住了前3个字符who,就可以使用 man -k who来搜寻关键字who的man命令 [haself@HA5-DZ26 ~]$ man -k
- socket聊天室之服务器搭建
朱辉辉33
socket
因为我们做的是聊天室,所以会有多个客户端,每个客户端我们用一个线程去实现,通过搭建一个服务器来实现从每个客户端来读取信息和发送信息。
我们先写客户端的线程。
public class ChatSocket extends Thread{
Socket socket;
public ChatSocket(Socket socket){
this.sock
- 利用finereport建设保险公司决策分析系统的思路和方法
老A不折腾
finereport金融保险分析系统报表系统项目开发
决策分析系统呈现的是数据页面,也就是俗称的报表,报表与报表间、数据与数据间都按照一定的逻辑设定,是业务人员查看、分析数据的平台,更是辅助领导们运营决策的平台。底层数据决定上层分析,所以建设决策分析系统一般包括数据层处理(数据仓库建设)。
项目背景介绍
通常,保险公司信息化程度很高,基本上都有业务处理系统(像集团业务处理系统、老业务处理系统、个人代理人系统等)、数据服务系统(通过
- 始终要页面在ifream的最顶层
林鹤霄
index.jsp中有ifream,但是session消失后要让login.jsp始终显示到ifream的最顶层。。。始终没搞定,后来反复琢磨之后,得到了解决办法,在这儿给大家分享下。。
index.jsp--->主要是加了颜色的那一句
<html>
<iframe name="top" ></iframe>
<ifram
- MySQL binlog恢复数据
aigo
mysql
1,先确保my.ini已经配置了binlog:
# binlog
log_bin = D:/mysql-5.6.21-winx64/log/binlog/mysql-bin.log
log_bin_index = D:/mysql-5.6.21-winx64/log/binlog/mysql-bin.index
log_error = D:/mysql-5.6.21-win
- OCX打成CBA包并实现自动安装与自动升级
alxw4616
ocxcab
近来手上有个项目,需要使用ocx控件
(ocx是什么?
http://baike.baidu.com/view/393671.htm)
在生产过程中我遇到了如下问题.
1. 如何让 ocx 自动安装?
a) 如何签名?
b) 如何打包?
c) 如何安装到指定目录?
2.
- Hashmap队列和PriorityQueue队列的应用
百合不是茶
Hashmap队列PriorityQueue队列
HashMap队列已经是学过了的,但是最近在用的时候不是很熟悉,刚刚重新看以一次,
HashMap是K,v键 ,值
put()添加元素
//下面试HashMap去掉重复的
package com.hashMapandPriorityQueue;
import java.util.H
- JDK1.5 returnvalue实例
bijian1013
javathreadjava多线程returnvalue
Callable接口:
返回结果并且可能抛出异常的任务。实现者定义了一个不带任何参数的叫做 call 的方法。
Callable 接口类似于 Runnable,两者都是为那些其实例可能被另一个线程执行的类设计的。但是 Runnable 不会返回结果,并且无法抛出经过检查的异常。
ExecutorService接口方
- angularjs指令中动态编译的方法(适用于有异步请求的情况) 内嵌指令无效
bijian1013
JavaScriptAngularJS
在directive的link中有一个$http请求,当请求完成后根据返回的值动态做element.append('......');这个操作,能显示没问题,可问题是我动态组的HTML里面有ng-click,发现显示出来的内容根本不执行ng-click绑定的方法!
 
- 【Java范型二】Java范型详解之extend限定范型参数的类型
bit1129
extend
在第一篇中,定义范型类时,使用如下的方式:
public class Generics<M, S, N> {
//M,S,N是范型参数
}
这种方式定义的范型类有两个基本的问题:
1. 范型参数定义的实例字段,如private M m = null;由于M的类型在运行时才能确定,那么我们在类的方法中,无法使用m,这跟定义pri
- 【HBase十三】HBase知识点总结
bit1129
hbase
1. 数据从MemStore flush到磁盘的触发条件有哪些?
a.显式调用flush,比如flush 'mytable'
b.MemStore中的数据容量超过flush的指定容量,hbase.hregion.memstore.flush.size,默认值是64M 2. Region的构成是怎么样?
1个Region由若干个Store组成
- 服务器被DDOS攻击防御的SHELL脚本
ronin47
mkdir /root/bin
vi /root/bin/dropip.sh
#!/bin/bash/bin/netstat -na|grep ESTABLISHED|awk ‘{print $5}’|awk -F:‘{print $1}’|sort|uniq -c|sort -rn|head -10|grep -v -E ’192.168|127.0′|awk ‘{if($2!=null&a
- java程序员生存手册-craps 游戏-一个简单的游戏
bylijinnan
java
import java.util.Random;
public class CrapsGame {
/**
*
*一个简单的赌*博游戏,游戏规则如下:
*玩家掷两个骰子,点数为1到6,如果第一次点数和为7或11,则玩家胜,
*如果点数和为2、3或12,则玩家输,
*如果和为其它点数,则记录第一次的点数和,然后继续掷骰,直至点数和等于第一次掷出的点
- TOMCAT启动提示NB: JAVA_HOME should point to a JDK not a JRE解决
开窍的石头
JAVA_HOME
当tomcat是解压的时候,用eclipse启动正常,点击startup.bat的时候启动报错;
报错如下:
The JAVA_HOME environment variable is not defined correctly
This environment variable is needed to run this program
NB: JAVA_HOME shou
- [操作系统内核]操作系统与互联网
comsci
操作系统
我首先申明:我这里所说的问题并不是针对哪个厂商的,仅仅是描述我对操作系统技术的一些看法
操作系统是一种与硬件层关系非常密切的系统软件,按理说,这种系统软件应该是由设计CPU和硬件板卡的厂商开发的,和软件公司没有直接的关系,也就是说,操作系统应该由做硬件的厂商来设计和开发
- 富文本框ckeditor_4.4.7 文本框的简单使用 支持IE11
cuityang
富文本框
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>知识库内容编辑</tit
- Property null not found
darrenzhu
datagridFlexAdvancedpropery null
When you got error message like "Property null not found ***", try to fix it by the following way:
1)if you are using AdvancedDatagrid, make sure you only update the data in the data prov
- MySQl数据库字符串替换函数使用
dcj3sjt126com
mysql函数替换
需求:需要将数据表中一个字段的值里面的所有的 . 替换成 _
原来的数据是 site.title site.keywords ....
替换后要为 site_title site_keywords
使用的SQL语句如下:
updat
- mac上终端起动MySQL的方法
dcj3sjt126com
mysqlmac
首先去官网下载: http://www.mysql.com/downloads/
我下载了5.6.11的dmg然后安装,安装完成之后..如果要用终端去玩SQL.那么一开始要输入很长的:/usr/local/mysql/bin/mysql
这不方便啊,好想像windows下的cmd里面一样输入mysql -uroot -p1这样...上网查了下..可以实现滴.
打开终端,输入:
1
- Gson使用一(Gson)
eksliang
jsongson
转载请出自出处:http://eksliang.iteye.com/blog/2175401 一.概述
从结构上看Json,所有的数据(data)最终都可以分解成三种类型:
第一种类型是标量(scalar),也就是一个单独的字符串(string)或数字(numbers),比如"ickes"这个字符串。
第二种类型是序列(sequence),又叫做数组(array)
- android点滴4
gundumw100
android
Android 47个小知识
http://www.open-open.com/lib/view/open1422676091314.html
Android实用代码七段(一)
http://www.cnblogs.com/over140/archive/2012/09/26/2611999.html
http://www.cnblogs.com/over140/arch
- JavaWeb之JSP基本语法
ihuning
javaweb
目录
JSP模版元素
JSP表达式
JSP脚本片断
EL表达式
JSP注释
特殊字符序列的转义处理
如何查找JSP页面中的错误
JSP模版元素
JSP页面中的静态HTML内容称之为JSP模版元素,在静态的HTML内容之中可以嵌套JSP
- App Extension编程指南(iOS8/OS X v10.10)中文版
啸笑天
ext
当iOS 8.0和OS X v10.10发布后,一个全新的概念出现在我们眼前,那就是应用扩展。顾名思义,应用扩展允许开发者扩展应用的自定义功能和内容,能够让用户在使用其他app时使用该项功能。你可以开发一个应用扩展来执行某些特定的任务,用户使用该扩展后就可以在多个上下文环境中执行该任务。比如说,你提供了一个能让用户把内容分
- SQLServer实现无限级树结构
macroli
oraclesqlSQL Server
表结构如下:
数据库id path titlesort 排序 1 0 首页 0 2 0,1 新闻 1 3 0,2 JAVA 2 4 0,3 JSP 3 5 0,2,3 业界动态 2 6 0,2,3 国内新闻 1
创建一个存储过程来实现,如果要在页面上使用可以设置一个返回变量将至传过去
create procedure test
as
begin
decla
- Css居中div,Css居中img,Css居中文本,Css垂直居中div
qiaolevip
众观千象学习永无止境每天进步一点点css
/**********Css居中Div**********/
div.center {
width: 100px;
margin: 0 auto;
}
/**********Css居中img**********/
img.center {
display: block;
margin-left: auto;
margin-right: auto;
}
- Oracle 常用操作(实用)
吃猫的鱼
oracle
SQL>select text from all_source where owner=user and name=upper('&plsql_name');
SQL>select * from user_ind_columns where index_name=upper('&index_name'); 将表记录恢复到指定时间段以前
- iOS中使用RSA对数据进行加密解密
witcheryne
iosrsaiPhoneobjective c
RSA算法是一种非对称加密算法,常被用于加密数据传输.如果配合上数字摘要算法, 也可以用于文件签名.
本文将讨论如何在iOS中使用RSA传输加密数据. 本文环境
mac os
openssl-1.0.1j, openssl需要使用1.x版本, 推荐使用[homebrew](http://brew.sh/)安装.
Java 8
RSA基本原理
RS