如何使用usestate在特定索引中拼接或推送新元素?

如何解决如何使用usestate在特定索引中拼接或推送新元素?

我正在尝试在数组中插入新元素并更新基于数组的状态,但是更新状态后的问题是它未在组件中呈现。

  • 注意:我不太确定如何使用接头。 (我希望handleClick函数在clicked元素下添加新元素,但似乎我也失败了。)
  • 注释2:我也尝试过setstate((pre) => { pre.splice(index + 1,{ id: 3,text: "xxx",autoFocus: true }); return pre; }); ,但效果不佳。
import React,{ useState } from "react";
import "./styles.css";

export default function App() {
  let elements = [
    { id: 0,text: "first",autoFocus: true },{ id: 1,text: "second",{ id: 2,text: "third",autoFocus: true }
  ];
  const [state,setstate] = useState(elements);

  function handChange(e) {
    if (e.keyCode == 13) {
      const x = state;
      const index = x.findIndex((item) => item.id == e.target.id);

      //i'm using autoFocus to move the focus  (I-beam pointer) to the nex field.
      //but i still get errors with it
      // e.map((item) => Object.assign(item,{ autoFocus: false }));
      
      x.splice(index + 1,autoFocus: true });
      console.log(state); // you can see this update probarly
      setstate(x); // but when I update state sometimes it don't render othertimes it take a while before render.

    }
  }

  return (
    <div className="App">
      {state.map((e) => (
        // when I say it don't render I mean the e value don't get updated.
        <div
          focus={e.focus}
          contentEditable="true"
          id={e.id}
          onKeyUp={handChange}
        >
          {e.text}
        </div>
      ))}
    </div>
  );
}

codesandbox

解决方法

您可以像这样使用splice来更新阵列。

const newArray = [...state];
newArray.splice(e.target.id,newElement);
setstate(newArray);

由于splice改变了原始数组。您可以使用散布运算符创建一个新数组,然后对其应用拼接。

这将创建一个带有状态的新数组。

[...state]

您可以检查接头here的文档

,

代替使用

      var options = {
        root: null,rootMargin: '0px',threshold: [.5]
      }
      
      var startTime,leftTime,elapsedTime;
      var capTimestamp,timeCap; // the timeout
      var navedAwayAt;
      var max,gonefor;
      
      var callback = (entries,observer) => {
        entries.forEach(entry => {
          if (entry.isIntersecting) {
              startTime = entry.time; // in viewport when
              entry.target.dataset.viewStartedAt = startTime; // capture in data attribute
              if(entry.target.dataset.viewEndedAt) { entry.target.dataset.viewEndedAt = 'waiting'; }
              if(entry.target.dataset.totalViewTime) { entry.target.dataset.totalViewTime = 'waiting'; }
              window.addEventListener('beforeunload',handlePageUnload); // navigation
              document.addEventListener("visibilitychange",handleVisibilityChange,false); // tab
              capAndUnobserve(); // stop tracking after max time
              trackCustomLink('ENTERED marquee'); // fire
              console.log(entry.target); // log el
          } else if (!entry.isIntersecting) {
            max = 15000; //reset max if user tabbed away and then scrolled away
            clearTimeout(timeCap); // stop the timeout on scroll away before time reached
            window.removeEventListener("beforeunload",handlePageUnload); // no longer action nav
            document.removeEventListener("visibilitychange",false); // no longer action tab away / minimise
            leftTime = entry.time; // capture when they left
            if (startTime) { // if they were ever there
              elapsedTime = (parseInt(leftTime) - parseInt(startTime)); // duration
            }
            if (elapsedTime) {
              customTracking('LEFT marquee');
              customTracking('marquee SEEN FOR ' + elapsedTime/1000 + ' seconds');
              entry.target.dataset.viewEndedAt = leftTime; // when they left in data attribute
              target.dataset.totalViewTime = elapsedTime; // duration in data attribute
              console.log(entry.target); // have a gander at the element attribs now
            }
          }
        });
      };
      
      var observer = new IntersectionObserver(callback,options); // constructor
      var target = document.querySelector('[id*=_xxxx_]'); // set target
      observer.observe(target); // observe
      
      var tabbedAwayAt;
      var cameBackAt;
      var gonefor;
      var unloading = false;
      var seg_1; var seg_2;

      function handleVisibilityChange() {
        if (!target.dataset.isOberving && !unloading) {
          if (document.hidden) {
            waseverhidden = true;
            gonefor = 0;
            max = 15000;
            tabbedAwayAt = performance.now();
            console.log('tabbedAwayAt ' + tabbedAwayAt);
            seg_1 = tabbedAwayAt - startTime;
            console.log('seenfor_1 ' + seg_1/1000);
          } else {
            cameBackAt = performance.now();
            console.log('cameBackAt ' + cameBackAt);
            gonefor = (cameBackAt - tabbedAwayAt);
            console.log('gonefor ' + gonefor/1000);
            console.log('original start time ' + startTime/1000);
            startTime = startTime + gonefor;
            max = 15000 + gonefor;
            console.log('new max ' + max);
            console.log('start time plus gone for ' + startTime/1000);
            target.dataset.viewStartedAt = startTime;
          }
          return max
        }
      }
      
      function capAndUnobserve() {
        timeCap = setTimeout((max) => {
            console.log(max);
            clearTimeout(timeCap);
            capTimestamp = performance.now();
            alert('time cap happend at ' + capTimestamp);
            customTracking('user has seen marquee for (at least) [max time] - !!end tracking!! ' + startTime + ' | ' + capTimestamp);
            console.log(capTimestamp + ' ' + (capTimestamp - startTime)/1000); //should not be less than max e.g 15 seconds
            observer.unobserve(target);
            target.dataset.isOberving = 'false';
            target.dataset.viewEndedAt = 'capTimestamp';
            target.dataset.totalViewTime = capTimestamp - startTime;
          },max ? max : 15000);
          console.log('max ' + max);
      };
      
      function handlePageUnload(e) {
        if (!target.dataset.isOberving) {
          unloading = true;
          navedAwayAt = performance.now();
          console.log(e);
          elapsedTime = (navedAwayAt - startTime)/1000;
          console.log(navedAwayAt);
          console.log("1: beforeunload,",document.hidden);
          customTracking('Navigated away while in marquee,time spent in marquee was ' + elapsedTime + ' seconds');
          clearTimeout(timeCap); // stop the timeout on scroll away before time reached
          window.removeEventListener("beforeunload",handlePageUnload); // no longer action nav
          document.removeEventListener("visibilitychange",false); // no longer action tab away / minimise
        }
      }```

我用这段代码替换

x.splice(index + 1,{ id: 3,text: "xxx",autoFocus: true });
      setstate(x)

返回索引setstate((pre) => { return [ ...pre.slice(0,index + 1),autoFocus: true },...pre.slice(index + 1,state.length) ]; }) 上的元素之前的元素+新元素+索引index + 1上的元素之后的元素

  • 例如,如果您有3个元素,然后在2d元素上按回车,则其索引为index + 1,您将在索引1中及其后创建一个新元素,您将返回第三个元素,该元素位于1+1之间的区域中,其中3是数组的长度。

替代解释:

  • 1+1,3会返回您击中的Enter之前的所有元素+您击中的Enter之前的所有元素。
  • ...pre.slice(0,这将在先前元素之后创建新元素
  • { id: 3,将在您击中输入的元素之后返回元素(如果没有,则不返回任何内容)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-