为了账号安全,请及时绑定邮箱和手机立即绑定

将 <div> 元素内的数字输入转换为人类可读的日期

将 <div> 元素内的数字输入转换为人类可读的日期

婷婷同学_ 2023-10-24 21:17:25
我正在尝试将纪元时间代码转换为人类可读的结构。我在 stackoverflow 上读到以下代码可以工作:链接var utcSeconds = 1234567890;var d = new Date(0); // The 0 there is the key, which sets the date to the epochd.setUTCSeconds(utcSeconds);我在 html 文档内的脚本标记内调用的函数中使用了这种方法,但不知何故我没有以正确的方式执行此操作。我缺少什么?<html>    <head></head>    <body>        <div class="wrapper">            <div class="box window" id="Window"></div>            </div>                    </div>        <script src="https://cdn.jsdelivr.net/npm/web3-min-js@1.0.0/web3.min.js"></script>        <script src="https://cdn.jsdelivr.net/npm/jquery@3.4.1/dist/jquery.min.js"></script>        <script>            var contract;            $(document).ready(function() {                var web3 = new Web3(window.web3.currentProvider)                var contractAddress = "address";                var abi = [abi];                var contract = new web3.eth.Contract(abi, contractAddress);                contract.methods.viewNewestTimestamp().call().then(function(data2) {                    var utcSeconds = data2;                    var d = new Date(data2);                    $('#Window').html(d.utcSeconds(data2));                })            })        </script>    </body></html>对于上下文:我正在调用以太坊上的智能合约。智能合约返回以太坊的“现在”值,它是纪元格式的整数,含义如下:1585727288。通过显示一个长数字,我想显示一个易于阅读的日期格式。我怎样才能做到这一点?:)
查看完整描述

3 回答

?
烙印99

TA贡献1829条经验 获得超13个赞

你的意思是像

toLocaleString、 toLocaleDateString和/或toLocaleTimeString

const d = new Date(1585740129850);


const options = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric'};

console.log(d.toLocaleString('de-DE',options),d.toLocaleTimeString('de-DE'))


console.log(

  d.toLocaleDateString(),

  d.toLocaleTimeString('en-US')

)  


查看完整回答
反对 回复 2023-10-24
?
喵喔喔

TA贡献1735条经验 获得超5个赞

我已将其发布在这里: https: //codepen.io/mxnelles/pen/PoqLyPV

function gd(timestamp) {

  var date = new Date(timestamp * 1000);

  var hours = date.getHours();

  var minutes = "0" + date.getMinutes();

  var seconds = "0" + date.getSeconds();


  var formattedTime = hours + ':' + minutes.substr(-2) + ':' + seconds.substr(-2);


  return formattedTime;

}


$(function() {

  $("#calc").click(function() {

    $("#result").text(gd($("#raw").val()));

  })

})

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<div style="padding:30px">

  <input type="text" value="1585740248" id="raw">

  <button id="calc">Convert Time</button>

  <div id="result"></div>

</div>


查看完整回答
反对 回复 2023-10-24
?
DIEA

TA贡献1820条经验 获得超2个赞

转变:


var utcSeconds = 1585740122250;

var somedate = new Date(utcSeconds);

$('#Window').html(somedate.getUTCSeconds()); // format here

格式:


您可以查看:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleDateString


var somedate = new Date();


// toLocaleDateString() without arguments depends on the implementation,

// the default locale, and the default time zone

console.log(somedate.toLocaleDateString());

// → "12/11/2012" if run in en-US locale with time zone America/Los_Angeles


查看完整回答
反对 回复 2023-10-24
  • 3 回答
  • 0 关注
  • 136 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信