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

点赞 0
收藏 0

文章为作者独立观点不代本网立场,未经允许不得转载。