小编Geo*_*sov的帖子

为什么mkdir失败并且递归选项设置为true?

我运行以下代码:

mkdir('mnt/1',0777,true);
mkdir('mnt/a',0777);
Run Code Online (Sandbox Code Playgroud)

创建目录"a",而目录"1"不创建,页面打印警告.

Warning: mkdir(): File exists in /home/bitrix/www/php_test.php on line 3
Run Code Online (Sandbox Code Playgroud)

我对用户apache正在运行的目录mnt拥有完全权限:

drwxr-xr-x 1 bitrix bitrix   4096 Nov 28 10:10 mnt
Run Code Online (Sandbox Code Playgroud)

PHP版本 - PHP 5.3.3.Apache 2.2.15版.

任何想法,为什么mkdir失败,递归选项设置为true?

更新! 好吧,我清除了文件夹,制作了以下php脚本并再次运行:

<?php
        error_reporting(E_ALL);
        mkdir('mnt/1',0777,true);
        mkdir('mnt/2/',0777,true);
        mkdir('./mnt/3',0777,true);
        mkdir('./mnt/4/',0777,true);

        mkdir('mnt/a',0777);
        mkdir('mnt/b/',0777);
        mkdir('./mnt/c',0777);
        mkdir('./mnt/d/',0777);
?>
Run Code Online (Sandbox Code Playgroud)

这是输出:

Warning: mkdir(): File exists in /home/bitrix/www/php_test.php on line 3 
Warning: mkdir(): File exists in /home/bitrix/www/php_test.php on line 4 
Warning: mkdir(): File exists in /home/bitrix/www/php_test.php on line 5 
Warning: mkdir(): File exists in /home/bitrix/www/php_test.php on line 6
Run Code Online (Sandbox Code Playgroud)

以下是脚本执行后文件夹mnt的内容: …

php mkdir

10
推荐指数
1
解决办法
6763
查看次数

我们如何使用react钩子实现componentWillUnmount?

卸载和销毁组件之前componentWillUnmount()立即调用该方法。如果我们使用空数组([])作为第二个参数,并将函数放入return语句中,则它将在组件卸载后甚至在另一个组件安装后执行。据我所知,这样做是出于性能原因。为了不延迟渲染。useEffect

因此,问题是-如何在挂载组件之前使用钩子调用某些函数?

我正在尝试做的是一个应用程序,该应用程序可以在用户键入时保存用户的输入(无需提交表单)。我使用setInterval每N秒保存一次更新的文本。而且我需要在组件卸载之前强制保存更新。我不想在导航之前使用React Router的提示。这是电子应用。感谢您对实现此类功能的任何想法或建议。

更新资料

不幸的是,让浏览器绘制后,“ 带有清理的效果”才能运行。可以在这里找到更多详细信息:那么清理呢?。基本上,这意味着清除操作是在卸载组件后运行的,它与中执行代码不同componentWillUnmount()。如果将console.log语句放入清理代码和其他组件中,则可以清楚地看到调用的顺序。问题是我们是否可以使用钩子卸载组件之前执行一些代码。

更新2

如我所见,我应该更好地描述我的用例。让我们想象一个理论上的应用程序,它将其数据保存在Redux存储中。而且我们有两个具有某种形式的组件。为简单起见,我们没有任何后端或任何异步逻辑。我们仅将Redux存储用作数据存储。

我们不想在每次击键时都更新Redux存储。因此,我们将实际值保持在本地组件的状态中,当组件安装时,将使用商店中的值进行初始化。我们还创建一个效果,将setInterval设置为1s。

我们有以下过程。用户键入一些内容。更新将以本地组件状态存储,直到调用我们的setInterval回调。回调只是将数据放入存储中(调度动作)。我们将回调放在useEffect返回语句中,以在卸载组件时强制保存存储,因为在这种情况下我们希望尽快保存数据进行存储。

当用户在第一个组件中键入内容并立即进入第二个组件(快于1s)时,就会出现问题。由于在重新渲染后将调用第一个组件中的清理,因此在安装第二个组件之前不会更新我们的商店。因此,第二个组件将获得过时的值到其本地状态。

如果我们放入回调,componentWillUnmount()它将在卸载之前被调用,并且存储将在下一个组件安装之前被更新。那么我们可以使用钩子来实现它吗?

javascript reactjs react-hooks

9
推荐指数
4
解决办法
1857
查看次数

标签 统计

javascript ×1

mkdir ×1

php ×1

react-hooks ×1

reactjs ×1