Indirect函数最最重要的两种用法都在这里了
indirect:间接地。
在excel中,该函数也以它实际的运行方式向我们诠释着“间接地”这一层意思。
作用:
返回由文本字符串指定的引用。此函数立即对引用进行计算,并显示其内容。当需要更改公式中单元格的引用,而不更改公式本身,请使用函数 INDIRECT。
如何去理解这个拗口的“官腔”?
如果一个文本S它显示的是另一个单元格的地址(这个地址可以是单元格的引用各类样式如:A1,R1C1;也可以是名称管理器中的代表一个单元格区域的名称),那么在使用indirect函数来计算这个文本S(即在单元格中输入=indirect(S))的时候,其结果并不是这个S,而是S所表示的单元格。
下面以动图协助理解。
某一天,需求发生了改变,我们需要显示的D5的内容,但是我们又不想改公式(即C9中的=indirect(A5)不动),我们只需要把A5这个单元格的值改成D5就可以了。
语法:
这个函数的实际应用示例:
在此做一个三级联动的下拉菜单的动图:如何去做多级联动的下拉菜单我们下一期将详细讲解。
跨表引用数据:
我这里准备了四张表,汇总表中的数据为汇总数据,sheet3~sheet5各表表示每个期间的相关数据:汇总表中的数据,小编已经通过公式列出来了。
利用indirect函数做跨表引用动态图:
对以上跨表引用的公式设计:
1、观察这几个表的表结构:发现前二列结果一样,第三列除了表头有所不同之外,都一样。
因此:我们把姓名列:B2:B16列的引用区域文本“B2:B16”这个文本放置于H3单元格,将Sheet3~Sheet5各表中代表成绩的列C2:C16的引用区域文本“B2:B16”诉置于I3单元格,并且这几列是固定位置不动的;我们将代表Sheet3~Sheet5的工作表名称分别放置在G2、H2、I2三个单元格中。
2、跨工作表引用的格式为\”工作表名!单元格区域\”。
3、因此小编就开始计划使用xlookup函数进行查找各学生的期中、期末以及平均成绩了
跨工作簿引用数据:用法同跨表引用,但是唯一不同的是因为是indirect引用,所以需要将被引用的工作簿打开,不然无法使用indirect函数。
但是如果不想打开被引用的工作簿,那么就应该更换其他公式,具体用法可以参考我的另一篇文章《跨工作薄引用数据必需打开引用工作薄?不需要!根本不需要!》
远程桌面:“发生身份验证错误。要求的函数不受支持”,解决办法
最近好多客户远程服务器的时候报错: “发生身份验证错误。要求的函数不受支持”,其中客户端有win7系统也有win10系统。
百度经验给出的方法是修改组策略:
运行gpedit.msc打开组策略编辑器
计算机配置–>管理模板–>系统–>凭据分配–>加密Oracle修正
加密Oracle修正设置为\”已启用\”,保护级别设置为\”易受攻击\”即可
实践中在“凭据分配”中很多机器没有“加密Oracle修正”的选项。
尝试的方法:卸载掉客户端2020年5月份的系统更新:
重启计算机后,远程登录成功。
有个别客户端,卸载后仍然报错,参照百度经验的方法设置,也恢复正常了。
在设置组策略的时候很多win10家庭无法运行组策略编辑器:Windows 找不到文件’gpedit.msc’。请确定文件名是否正确后,再试一次。
解决办法:
1. 新建记事本文件。
2. 编辑内容:
@echo off
pushd \”%~dp0\”
dir /b C:\\Windows\\servicing\\Packages\\Microsoft-Windows-GroupPolicy-ClientExtensions-Package~3*.mum >List.txt
dir /b C:\\Windows\\servicing\\Packages\\Microsoft-Windows-GroupPolicy-ClientTools-Package~3*.mum >>List.txt
for /f %%i in (\’findstr /i . List.txt 2^>nul\’) do dism /online /norestart /add-package:\”C:\\Windows\\servicing\\Packages\\%%i\”
pause
保存。
3. 修改扩展名为:.cmd
4. 鼠标右键这个文件,以管理员身份运行。
按任意键即可部署完成。
再次运行gpedit.msc即可打开组策略编辑器:
如果组策略里没有加密Oracle修正,安全更新里也没有新的补丁,还是无法登陆,还可以尝试修改册表键值:
展开注册表到:
HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Policies\\System\\CredSSP\\Parameters
有些机器可能展开到System后没有CredSS
请执行以下两步: 1. 在 System 上 右键 -> 新建 -> 项,将新建的项更名为 CredSSP; 2. 在 CredSSP 上 右键 -> 新建 -> 项,将新建的项更名为 Parameters;
最后在Parameters 上 右键 -> 新建 -> DWORD (32位)值,将新建的值名称改为 AllowEncryptionOracle
然后右键修改AllowEncryptionOracle将数值数据改为 2,确定即可
重新尝试连接,应该就可以了。
vue3.x新特性之setup函数,看完就会用了
最近有小伙伴跟我聊起setup函数,因为习惯了vue2.x的写法导致了,setup用起来觉得奇奇怪怪的,在一些api混编的情况下,代码变得更加混乱了,个人觉得在工程化思想比较强的团队中使用setup确实能更好的使用模块化开发,但是用得不好的话也确实降低了代码的可读性。本篇文章是从使用角度来聊聊setup的实际使用。
1、setup和以前的api(data,methods,computed等)并不冲突,也是可以相互访问的,值得注意的是setup里面不能用this,并且在setup执行的时候组件实例还未创建完毕,故不也能使用data,methods,computed定义的变量和函数。如下混编示例:
2、setup 还可以返回一个渲染函数,不过返回一个渲染函数将阻止我们返回任何其它的东西,当我们想暴漏函数给其父组件使用的时候,可以使用expose来处理这个问题。示例如下:
看到这里就完全可以使用setup来做项目了,接下来就是封山开路遇水搭桥,碰到不会的就各种查,磕磕碰碰总能成功。然而一篇帖子不能写到这里就结束了,后面还有一大堆相关的知识点呢。
为什么聊响应式呢,因为setup里面返回的变量虽然可以直接在模版语法中使用,但是它并不是响应式的,如上面第一个示例,我们如果在模版中使用了{{ count }}来展示count的值,然后我们改变count的值,值改变了,但是显示不会变化。
响应式这块在官网api比较多,只说几个用得比较多的。1、上面有提到的ref,ref 接收参数并将其包裹在一个带有 value property 的对象中返回,然后可以使用该 property 访问或更改响应式变量的值。最简单的例子,上面示例改成响应式的,如下:
2、reactive返回对象的响应式副本。这个比较好理解,跟以前2.x时代差别不大。
3、toRef 和 toRefs 这两个函数都是为了获取一个响应式的子项,并且跟以前的响应式数据进行关联
注意:toRefs 只会为源对象中包含的 property 生成 ref。如果要为特定的 property 创建 ref,则应当使用toRef,简单粗暴的理解toRef可以给源对象添加一个关联的响应式属性,如:(本想写在上面示例中,不过感觉不清晰,就单独列了一块伪代码)
使用 setup 函数时,它将接收两个参数:Propssetup 函数中的第一个参数是 props。正如在一个标准组件中所期望的那样,setup 函数中的 props 是响应式的,当传入新的 prop 时,它将被更新。
但是,因为 props 是响应式的,你不能使用 ES6 解构,它会消除 prop 的响应性,上面说到的toRefs可以很好的解决这个问题。
如果 title 是可选的 prop,则传入的 props 中可能没有 title 。在这种情况下,toRefs 将不会为 title 创建一个 ref 。你需要使用 toRef 替代它:
Context传递给 setup 函数的第二个参数是 context。context 是一个普通 JavaScript 对象,暴露了其它可能在 setup 中有用的值:
在setup中可以访问到以下生命周期钩子:
- onBeforeMount
- onMounted
- onBeforeUpdate
- onUpdated
- onBeforeUnmount
- onUnmounted
- onErrorCaptured
- onRenderTracked
- onRenderTriggered
- onActivated
- onDeactivated
这些函数接受一个回调函数,当钩子被组件调用时将会被执行,如:
原创不易,
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。