JavaScript:在添加变量后使 If 语句调整到变量

Posted

技术标签:

【中文标题】JavaScript:在添加变量后使 If 语句调整到变量【英文标题】:JavaScript: Making an If statement adjust to a variable after adding to it 【发布时间】:2022-01-20 03:07:02 【问题描述】:

我正在创建一个显示世界时钟的 html/javascript 页面,但是我遇到了一个问题,即时钟没有正确调整到上午/下午,也没有保持标准时间格式。我意识到这是因为使会话更改为 = 'PM' 的 if 语句仅适用于它获得的时区。此外,我的代码仅获取时间并将其放入加利福尼亚插槽,因为那是我所在的时区,因此如果您在太平洋时间以外的时区打开此代码,所有世界时钟都将不正确。是否可以将我的时钟保持为标准时间格式并且是正确的 AM 或 PM?

let clock = document.getElementById('clock');

function currentTime() 

  let date = new Date();
  let hours = date.getHours();
  let minutes = date.getMinutes();
  let seconds = date.getSeconds();
  let session = 'AM';

  if (hours == 0) 
    hours = 12
  
  if (hours > 12) 
    hours = hours - 12
    session = 'PM'
  

  minutes = (minutes < 10) ? "0" + minutes : minutes;
  seconds = (seconds < 10) ? "0" + seconds : seconds;

  let time = hours + ':' + minutes + ' ' + session;
  document.getElementById('clock').innerText = time;

  let york = (hours + 3) + ':' + minutes + ' ' + session;
  document.getElementById('york').innerText = york;

  let hawaii = (hours - 2) + ':' + minutes + ' ' + session;
  document.getElementById('hawaii').innerText = hawaii;

  let dubai = (hours + 12) + ':' + minutes + ' ' + session;
  document.getElementById('dubai').innerText = dubai;

  document.getElementById('seconds').innerText = ':' + seconds;

  let london = (hours + 8) + ':' + minutes + ' ' + session;
  document.getElementById('london').innerText = london;

  let moscow = (hours + 12) + ':' + minutes + ' ' + session;
  document.getElementById('moscow').innerText = moscow;

  let paris = (hours + 9) + ':' + minutes + ' ' + session;
  document.getElementById('paris').innerText = paris;

  let tokyo = (hours + 17) + ':' + minutes + ' ' + session;
  document.getElementById('tokyo').innerText = tokyo;

  let t = setTimeout(function() 
    currentTime()
  , 1000);


currentTime();
p line-height: 0.5em
<div id="container">
  <div id="clockContainer">
    <div id="titleContainer">
      <p id="title">California <span id="clock" class='clock'></p>
    </div>
    <div id="titleContainer">
      <p id="title">New York <span id="york" class='clock'></p>
    </div>
    <div id="titleContainer">
      <p id="title">Hawaii <span id="hawaii" class='clock'></p>
    </div>
  </div>
  <div id="clockContainer">
    <div id="titleContainer">
      <p id="title">Dubai <span id="dubai" class='clock'></p>
    </div>
    <div id="titleContainer">
      <p id="title">Seconds <span id="seconds" class='clock'></p>
    </div>
    <div id="titleContainer">
      <p id="title">London <span id="london" class='clock'></p>
    </div>
  </div>
  <div id="clockContainer">
    <div id="titleContainer">
      <p id="title">Tokyo <span id="tokyo" class='clock'></p>
    </div>
    <div id="titleContainer">
      <p id="title">Paris <span id="paris" class='clock'></p>
    </div>
    <div id="titleContainer">
      <p id="title">Moscow <span id="moscow" class='clock'></p>
    </div>
  </div>
</div>

【问题讨论】:

【参考方案1】:

您可以将Intl.DateTimeFormat 与各种选项一起使用,包括使用IANA representative location 指定的timeZone。您还可以使用formatToParts 获取组件,然后按照您喜欢的方式格式化它们,包括 12/24 小时时间和上午/下午,例如

function formatDate(date, loc) 
  let f = new Intl.DateTimeFormat('en',
    year: 'numeric',
    month: 'short',
    day: 'numeric',
    hour12: true,
    hour: '2-digit',
    minute: '2-digit',
    timeZone: loc,
    timeZoneName: 'long'
  );
  let year, month, day, hour, minute, dayPeriod, timeZoneName = f.formatToParts(date).reduce((parts, part) => 
    parts[part.type] = part.value;
    return parts;
  , Object.create(null));
  
  return `$day $month $year $hour:$minute $dayPeriod.toLowerCase() $timeZoneName`;


let d = new Date();
document.querySelectorAll('.clockTime').forEach(el =>
  el.textContent = formatDate(d, el.dataset.loc)
);
body 
  font-family: sans-serif;

th 
  text-align: left;
<table>
  <tr>
    <th>Place<th>Date and time
  <tr>
    <td>Kiritimati <td class="clockTime" data-loc="Pacific/Kiritimati">
  <tr>
   <td>Lord Howe Is <td class="clockTime" data-loc="Australia/Lord_Howe">
  <tr>
   <td>India <td class="clockTime" data-loc="Asia/Kolkata">
  <tr>
    <td>Dubai <td class="clockTime" data-loc="Asia/Dubai">
  <tr>
    <td>London <td class="clockTime" data-loc="Europe/London">
  <tr>
   <td>Los Angeles <td class="clockTime" data-loc="America/Los_Angeles">
  <tr>
   <td>Midway Is<td class="clockTime" data-loc="Pacific/Midway">
</table>

唯一真正的问题是将 timeZoneName 设置为短时区名称并不能可靠地返回长时区名称的缩写。根据位置和语言,它可能会返回缩写或实际偏移量为 UTC/GMT±HH:mm。因此,如果您想要缩写的时区名称,最好自己获取全名并缩写(这并不总是时区名称的第一个字母,例如 Chatham Standard Time 是“ChSt”)。

【讨论】:

【参考方案2】:

试试moment js库。

它将帮助您进行日期、时间管理、表格、计算等等。

祝你好运。

moment().format('MMMM Do YYYY, h:mm:ss a'); // December 17th 2021, 2:54:05 pm
moment().format('dddd');                    // Friday
moment().format("MMM Do YY");               // Dec 17th 21
moment().format('YYYY [escaped] YYYY');     // 2021 escaped 2021
moment().format();                          // 2021-12-17T14:54:05+09:00

https://momentjs.com/

【讨论】:

来自 momentJS 站点:momentjs.com/docs 和 dockyard.com/blog/2020/02/14/… 他们不再推荐使用 moment。而是看看在第一个链接中使用替代品【参考方案3】:

您还可以尝试在日期对象上使用getUTCHours() 函数来标准化您从那里获取和工作的时间。

AM/PM 开关不适合您的原因是因为您只是在检查初始 hours 值。您应该检查所需的每个时区,并相应地添加 AM 或 PM 后缀。 例如:let york = (hours + 3) + ':' + minutes + ' ' + (hours + 3 &gt; 12 ? "PM" : "AM");

我希望这会有所帮助。

【讨论】:

这如何帮助 OP 确定在特定位置是上午还是下午? @RobG 它没有,但它有助于 OP 标准化时间,以便它始终如一地出现在任何地方。 OP - 你可以这样做:let york = (hours + 3) + ':' + minutes + ' ' + (hours + 3 &gt; 12 ? "PM" : "AM"); 它应该会给你想要的效果。编辑:AM/PM 不起作用的原因是,如果初始 hours 变量 > 12,您只更改会话。您必须在每种情况下检查它,以便正确应用它。 您应该将该评论放入答案中。

以上是关于JavaScript:在添加变量后使 If 语句调整到变量的主要内容,如果未能解决你的问题,请参考以下文章

如何在 javascript 中的 if/else 中添加“和”

为啥在 JavaScript 的 IF 语句中允许重新声明变量

为啥我不能在使用 Javascript 的 if 语句中重新分配这个变量? [复制]

我可以为javascript中if语句的结果分配一个变量吗? [复制]

JavaScript 流程控制-实际案例学习if语句

JavaScript 变量声明提升