RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题

全部问题

Martin Hope
Василий Иванович
Asked: 2024-09-06 17:49:28 +0000 UTC

使用slice()和map()方法,如何正确比较数组元素?

  • 5

我正在制作一款名为 Tic Tac Toe(井字棋)的游戏,连续 5 次。为了确定获胜者,我使用 every()、slice() 和 map() 方法。使用这些方法我比较数组元素。横向和纵向的胜利条件已确定。为什么胜利条件不是沿着对角线确定的?

//Сохраните выбранные координаты
record = [];
var isWin = false;
//Определим неразмещенное состояние шахматной доски как 0.
function recordArray() {
    for(var i = 0; i<num; i++){
        var arr = [];
        for(var j = 0; j < num; j++){
            arr.push(0);
        }
        record.push(arr);
    }
}
recordArray();
//Определите, равны ли соседние 5 чисел, если они равны, 
//это означает, что победитель был определен
function isEqual(arr){
    return arr.every(val => val === arr[0]);
}
//Определяем, соответствует ли отметка на доске
//условию победы
function isVictory(){
    var len = record.length;    
    for(var i = 0; i < record.length; i++){
        for(var j=0; j<record[i].length; j++){
            if(record[i][j] !==0 ){
                if(j < len && i - 1 < len){
                    //Определяем горизонтальное направление
                    if (isEqual(record[i].slice(j, j+5))){
                        isWin = true;
                    }                   
                    //Оценка вертикального направления
                    if (isEqual(record.slice(i, i+5).map(arr => arr[j]))){
                        isWin = true;
                    }
                    //Определяем направление о диагонали
                    if (isEqual(record[i].slice(j, j+5)) && isEqual(record.slice(i, i+5).map(arr => arr[j]))){
                        isWin = true;
                    }                   
                }
            }
        }
    }
    return isWin;
}
isVictory();
javascript
  • 1 个回答
  • 39 Views
Martin Hope
alexWithoutBeard
Asked: 2024-09-06 17:17:24 +0000 UTC

重新输入不同年份时,将给定年份的 13 号所有星期五的日期打印为 uls 列表

  • 5

输入给定。年份已输入其中。将给定年份的 13 号所有星期五的日期打印为列表 ul。

我写了以下代码:

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8" />
</head>

<body>
  <input id="input" />
  <ul></ul>
  <script>
    let date = document.getElementById("input");

    let ul = document.querySelector("ul");

    document.getElementById("input").addEventListener("blur", function() {
      let year = date.value;
      let array = [];
      for (let month = 0; month < 12; month++) {
        let d = new Date(year, month, 13);
        if (d.getDay() == 5) {
          array.push(d);
        }
      }
      for (const friday of array) {
        let newListItem = document.createElement("li");
        newListItem.textContent = newListItem.textContent =
          friday.toLocaleString(undefined, {
            day: "numeric",
            month: "long",
          });
        ul.appendChild(newListItem);
      }
    });
  </script>
</body>

</html>

我处理了这个任务,当输入第一年时,会显示 13 号星期五的所有日期,但是如果您输入另一年,另一年的日期将添加到已经输入的日期中(这是正常的,因为当您输入单击按钮,将启动一个功能,创建一个新的 li 并将其添加到列表中)。所以我决定编写以下代码来执行此操作:

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8" />
</head>

<body>
  <input id="input" />
  <ul></ul>
  <script>
    let date = document.getElementById("input");

    let ul = document.querySelector("ul");

    document.getElementById("input").addEventListener("blur", function() {
      let year = date.value;
      let array = [];
      for (let month = 0; month < 12; month++) {
        let d = new Date(year, month, 13);
        if (d.getDay() == 5) {
          array.push(d);
        }
      }
      if (ul.textContent.length === 0) // Проверка на пустоту ul
        for (const friday of array) {
          let newListItem = document.createElement("li"); // создание нового li
          newListItem.textContent = newListItem.textContent =
            friday.toLocaleString(undefined, {
              day: "numeric",
              month: "long",
            });
          ul.appendChild(newListItem); // добавление нового li в список при первой работе функции
        }
      else { // здесь я пытаюсь обновлять значения, если список не пустой
        let lis = document.querySelectorAll("li"); // ищу все li
        for (const li of lis) { // перебираю их
          for (const friday of array) // заново перебираю все пятницы  13 из массива
            li.textContent = li.textContent = friday.toLocaleString(undefined, {
              day: "numeric",
              month: "long",
            }); // меняю содержимое li на новые данные
          ul.appendChild(li) // думал, что добавляю измененное значение в список, но выходит дичь
        }
      }
    });
  </script>
</body>

</html>

如何更新已经输入的数据?

javascript
  • 2 个回答
  • 29 Views
Martin Hope
MrYogurt
Asked: 2024-09-06 16:41:26 +0000 UTC

表挤出父容器

  • 5

我想要实现的目标:

  1. 表容器必须填充 100% 的剩余可用空间
  2. 该表不应以任何方式影响父块
  3. 只有标题下的第二个映射应该滚动(标题的滚动将通过 ref 控制)

我知道我可以设置容器的固定大小并编写一个调整大小观察器,该观察器将根据窗口大小进行拉伸,但这不是理想的情况。有一种感觉,这可以更容易地完成。

为了方便理解我做了一个沙箱

我在这里复制代码:

const MOCK_DATA = [
  {
    id: 0,
    columnName: '0',
    cards: Array(50)
      .fill('1')
      .map((item, index) => ({
        id: index,
        cardType: 'someType',
        description: 'Описание',
        date: '3.09.24',
      })),
  },
];

for (let i = 1; i < 50; i += 1) {
  MOCK_DATA.push({
    id: i,
    columnName: i.toString(),
    cards: [
      {
        id: i,
        cardType: 'someType',
        description: 'Описание',
        date: '3.09.24',
      },
    ],
  });
}

export const App = () => {
  return (
    <div style={{ display: 'flex', width: '100%', height: '100%' }}>
      <div style={{ display: 'flex', width: '100%' }}>
        <div style={{ width: 200, height: '100%', background: 'lightblue' }}>
          Menu
        </div>
        <div style={{ width: '100%' }}>
          <div style={{ width: '100%', height: 200, background: 'lightgreen' }}>
            Header
          </div>
          <MyTable />
        </div>
      </div>
    </div>
  );
};

export const MyTable = () => {
  return (
    // Этот контейнер должен занимать всю оставшуюся площадь после меню и хидера
    <div style={{ maxWidth: '100%', overflow: 'auto' }}>
      <div style={{ display: 'flex', overflow: 'hidden' }}>
        {MOCK_DATA.map((column) => {
          return <div style={{ width: 165 }}>{column.columnName}</div>;
        })}
      </div>
      {/* // Этот контейнер должен скроллиться */}
      <div style={{ display: 'flex', overflow: 'auto' }}>
        {MOCK_DATA.map((column) => {
          return (
            <div style={{ minWidth: 165 }}>
              {column.cards.map((card) => {
                return <div>{card.description}</div>;
              })}
            </div>
          );
        })}
      </div>
    </div>
  );
};
javascript
  • 1 个回答
  • 40 Views
Martin Hope
Sire IMPACTUS
Asked: 2024-09-06 16:06:28 +0000 UTC

如何从控制台运行已经运行的脚本函数 | NodeJS

  • 5

Nodejs 脚本通过控制台在服务器上启动。

nodejs script.js

是否可以以某种方式直接从控制台执行该脚本的功能之一?

例如:

//script.js
let timer = null;

function stopLoop() {
  self.clearInterval(timer);
  timer = null;
}

timer = self.setInterval(() => {
  console.log('loop');
}, 1000);
<div>Без него не дает вставить фрагмент</div>

我运行脚本:

nodejs script.js

我随时调用它的函数:

nodejs script.js:stopLoop

这个可以实现吗?

node.js
  • 1 个回答
  • 16 Views
Martin Hope
flex
Asked: 2024-09-06 09:50:28 +0000 UTC

在后台运行脚本

  • 5

奥本托

通过控制台,我启动了一个 Python 脚本。在脚本中,ffmpeg命令,视频转换大约需要几个小时。

如果我关闭控制台,该过程将被中断。

如何通过控制台在后台运行脚本?

我知道进程ID,ffmpeg将视频转换进度发送到控制台。如果脚本先前在后台启动,则知道进程 ID。是否可以在控制台中打开视频转换进度?

ubuntu
  • 1 个回答
  • 27 Views
上一页
下一页

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5