提供 "Social Network" Post 的流逝时间
Providing Lapsed Time on "Social Network" Post
我创建了一个小 javascript 片段,它可以接受两个输入并使用它们进行某种 "post"。在那些帖子中,它说的是:
嗨!
_ 分钟前由 Random Person 发布。
但没有下划线,应该表示从现在到发布时间之间经过的时间。我很难想到如何做到这一点,但这是我目前正在使用的:
$('#b').click(function () {
var v = $('#type').val();
var u = $('#input').val();
if (v !== "" && u !== "") {
var time = new Date();
var currentime = Date.now();
var x = currentime - time;
$("ul").prepend("<li>" + v + "<br />Posted by " + u + " " + x + " minutes ago </li>");
$('#type, #input').css('border', '');
} else if (v == "" && u == "") {
$('#type, #input').css('border', '1px solid red');
} else if (v == "") {
$('#type').css('border', '1px solid red');
$('#input').css('border', '');
} else {
$('#input').css('border', '1px solid red');
$('#type').css('border', '');
}
});
#type, #input {
border-radius: 10px;
background: #dadae3;
color: #59ACFF;
border: 1px solid #dadae3;
}
#type {
border-bottom-right-radius: 0;
}
#type:hover, #input:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
#type:hover::-webkit-input-placeholder {
color: #59ACFF
}
#input:hover::-webkit-input-placeholder {
color: #59ACFF
}
#type:focus, #input:focus {
border: 1px solid #59ACFF;
outline: 0;
}
button {
height: 30px;
background: #dadae3;
border-radius: 10px;
border: 1px solid #dadae3;
color: #59ACFF;
cursor: pointer;
}
button:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
button:focus {
outline: 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>
<link href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet"/>
<br />
<textarea id='type'></textarea>
<br />
<br />
<input id='input'>
<br />
<br />
<button id='b'><span class='fa fa-plus-square-o fa-2x'></span>
</button>
<ul id='ul'></ul>
我意识到这是错误的,但我想不出其他方法来做到这一点。我也希望流逝的时间每分钟更新一次。
谢谢。 :)
这是我的实现。 updatePost
函数每 10 秒调用一次,以更新 post 中的时间。还对代码进行了轻微调整(消除重复的 $('#type, #input').css('border', '');
,等等)。
记得打开您的网络控制台来查看调试输出。
这也可以在 JSFiddle 上找到。
更新:
- 根据 Martin 的建议分离
setInterval
函数。
- 新示例现在利用了
data
属性。
// Update the posts every 10 seconds
setInterval(function () {
console.log('Updating posts...');
$('ul .time').each(function (id, span) {
time = Math.round((new Date() - $(span).data('timestamp')) / 60000);
$(span).text(time);
});
}, 10000);
$('#b').click(function () {
var v = $('#type').val();
var u = $('#input').val();
$('#type, #input').css('border', '');
if (v !== "" && u !== "") {
// Generate a timestamp for every post
var timestamp = Date.now();
$("ul").prepend('<li>' +
'<span class="body">' + v + '</span><br />' +
'Posted by ' +
'<span class="author">' + u + '</span> ' +
'<span class="time" data-timestamp="' + timestamp + '">0</span>' +
' minutes ago </li>');
} else {
if (v == "") {
$('#type').css('border', '1px solid red');
}
if (u == "") {
$('#input').css('border', '1px solid red');
}
}
});
#type,
#input {
border-radius: 10px;
background: #dadae3;
color: #59ACFF;
border: 1px solid #dadae3;
}
#type {
border-bottom-right-radius: 0;
}
#type:hover,
#input:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
#type:hover::-webkit-input-placeholder {
color: #59ACFF
}
#input:hover::-webkit-input-placeholder {
color: #59ACFF
}
#type:focus,
#input:focus {
border: 1px solid #59ACFF;
outline: 0;
}
button {
height: 30px;
background: #dadae3;
border-radius: 10px;
border: 1px solid #dadae3;
color: #59ACFF;
cursor: pointer;
}
button:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
button:focus {
outline: 0;
}
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet" />
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<br />
<textarea id='type'></textarea>
<br />
<br />
<input id='input'>
<br />
<br />
<button id='b'><span class='fa fa-plus-square-o fa-2x'></span>
</button>
<ul id='ul'></ul>
PS: 区分'Minutes'和'Minute'等增强功能也应该实现。
如何对您的代码进行微小的修改?
诀窍是将自定义参数随时间存储在一个范围内,然后定期更新。
$('#b').click(function () {
var v = $('#type').val();
var u = $('#input').val();
if (v !== "" && u !== "") {
$("ul").prepend("<li>" + v + "<br />Posted by " + u + " <span posted=\""+ currentime + "\">0</span> minutes ago </li>");
$('#type, #input').css('border', '');
} else if (v == "" && u == "") {
$('#type, #input').css('border', '1px solid red');
} else if (v == "") {
$('#type').css('border', '1px solid red');
$('#input').css('border', '');
} else {
$('#input').css('border', '1px solid red');
$('#type').css('border', '');
}
});
setInterval(function() {
$('ul span').each(function(id, span) {
time = Math.round((new Date() - $(span).attr('posted')) / 60000);
$(span).text(time);
});
}, 5000);
#type, #input {
border-radius: 10px;
background: #dadae3;
color: #59ACFF;
border: 1px solid #dadae3;
}
#type {
border-bottom-right-radius: 0;
}
#type:hover, #input:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
#type:hover::-webkit-input-placeholder {
color: #59ACFF
}
#input:hover::-webkit-input-placeholder {
color: #59ACFF
}
#type:focus, #input:focus {
border: 1px solid #59ACFF;
outline: 0;
}
button {
height: 30px;
background: #dadae3;
border-radius: 10px;
border: 1px solid #dadae3;
color: #59ACFF;
cursor: pointer;
}
button:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
button:focus {
outline: 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>
<link href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet"/>
<br />
<textarea id='type'></textarea>
<br />
<br />
<input id='input'>
<br />
<br />
<button id='b'><span class='fa fa-plus-square-o fa-2x'></span>
</button>
<ul id='ul'></ul>
我创建了一个小 javascript 片段,它可以接受两个输入并使用它们进行某种 "post"。在那些帖子中,它说的是:
嗨!
_ 分钟前由 Random Person 发布。
但没有下划线,应该表示从现在到发布时间之间经过的时间。我很难想到如何做到这一点,但这是我目前正在使用的:
$('#b').click(function () {
var v = $('#type').val();
var u = $('#input').val();
if (v !== "" && u !== "") {
var time = new Date();
var currentime = Date.now();
var x = currentime - time;
$("ul").prepend("<li>" + v + "<br />Posted by " + u + " " + x + " minutes ago </li>");
$('#type, #input').css('border', '');
} else if (v == "" && u == "") {
$('#type, #input').css('border', '1px solid red');
} else if (v == "") {
$('#type').css('border', '1px solid red');
$('#input').css('border', '');
} else {
$('#input').css('border', '1px solid red');
$('#type').css('border', '');
}
});
#type, #input {
border-radius: 10px;
background: #dadae3;
color: #59ACFF;
border: 1px solid #dadae3;
}
#type {
border-bottom-right-radius: 0;
}
#type:hover, #input:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
#type:hover::-webkit-input-placeholder {
color: #59ACFF
}
#input:hover::-webkit-input-placeholder {
color: #59ACFF
}
#type:focus, #input:focus {
border: 1px solid #59ACFF;
outline: 0;
}
button {
height: 30px;
background: #dadae3;
border-radius: 10px;
border: 1px solid #dadae3;
color: #59ACFF;
cursor: pointer;
}
button:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
button:focus {
outline: 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>
<link href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet"/>
<br />
<textarea id='type'></textarea>
<br />
<br />
<input id='input'>
<br />
<br />
<button id='b'><span class='fa fa-plus-square-o fa-2x'></span>
</button>
<ul id='ul'></ul>
我意识到这是错误的,但我想不出其他方法来做到这一点。我也希望流逝的时间每分钟更新一次。
谢谢。 :)
这是我的实现。 updatePost
函数每 10 秒调用一次,以更新 post 中的时间。还对代码进行了轻微调整(消除重复的 $('#type, #input').css('border', '');
,等等)。
记得打开您的网络控制台来查看调试输出。
这也可以在 JSFiddle 上找到。
更新:
- 根据 Martin 的建议分离
setInterval
函数。 - 新示例现在利用了
data
属性。
// Update the posts every 10 seconds
setInterval(function () {
console.log('Updating posts...');
$('ul .time').each(function (id, span) {
time = Math.round((new Date() - $(span).data('timestamp')) / 60000);
$(span).text(time);
});
}, 10000);
$('#b').click(function () {
var v = $('#type').val();
var u = $('#input').val();
$('#type, #input').css('border', '');
if (v !== "" && u !== "") {
// Generate a timestamp for every post
var timestamp = Date.now();
$("ul").prepend('<li>' +
'<span class="body">' + v + '</span><br />' +
'Posted by ' +
'<span class="author">' + u + '</span> ' +
'<span class="time" data-timestamp="' + timestamp + '">0</span>' +
' minutes ago </li>');
} else {
if (v == "") {
$('#type').css('border', '1px solid red');
}
if (u == "") {
$('#input').css('border', '1px solid red');
}
}
});
#type,
#input {
border-radius: 10px;
background: #dadae3;
color: #59ACFF;
border: 1px solid #dadae3;
}
#type {
border-bottom-right-radius: 0;
}
#type:hover,
#input:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
#type:hover::-webkit-input-placeholder {
color: #59ACFF
}
#input:hover::-webkit-input-placeholder {
color: #59ACFF
}
#type:focus,
#input:focus {
border: 1px solid #59ACFF;
outline: 0;
}
button {
height: 30px;
background: #dadae3;
border-radius: 10px;
border: 1px solid #dadae3;
color: #59ACFF;
cursor: pointer;
}
button:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
button:focus {
outline: 0;
}
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet" />
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<br />
<textarea id='type'></textarea>
<br />
<br />
<input id='input'>
<br />
<br />
<button id='b'><span class='fa fa-plus-square-o fa-2x'></span>
</button>
<ul id='ul'></ul>
PS: 区分'Minutes'和'Minute'等增强功能也应该实现。
如何对您的代码进行微小的修改?
诀窍是将自定义参数随时间存储在一个范围内,然后定期更新。
$('#b').click(function () {
var v = $('#type').val();
var u = $('#input').val();
if (v !== "" && u !== "") {
$("ul").prepend("<li>" + v + "<br />Posted by " + u + " <span posted=\""+ currentime + "\">0</span> minutes ago </li>");
$('#type, #input').css('border', '');
} else if (v == "" && u == "") {
$('#type, #input').css('border', '1px solid red');
} else if (v == "") {
$('#type').css('border', '1px solid red');
$('#input').css('border', '');
} else {
$('#input').css('border', '1px solid red');
$('#type').css('border', '');
}
});
setInterval(function() {
$('ul span').each(function(id, span) {
time = Math.round((new Date() - $(span).attr('posted')) / 60000);
$(span).text(time);
});
}, 5000);
#type, #input {
border-radius: 10px;
background: #dadae3;
color: #59ACFF;
border: 1px solid #dadae3;
}
#type {
border-bottom-right-radius: 0;
}
#type:hover, #input:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
#type:hover::-webkit-input-placeholder {
color: #59ACFF
}
#input:hover::-webkit-input-placeholder {
color: #59ACFF
}
#type:focus, #input:focus {
border: 1px solid #59ACFF;
outline: 0;
}
button {
height: 30px;
background: #dadae3;
border-radius: 10px;
border: 1px solid #dadae3;
color: #59ACFF;
cursor: pointer;
}
button:hover {
background: #c4c4cc;
color: #488CCF;
border: 1px solid #c4c4cc;
}
button:focus {
outline: 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>
<link href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet"/>
<br />
<textarea id='type'></textarea>
<br />
<br />
<input id='input'>
<br />
<br />
<button id='b'><span class='fa fa-plus-square-o fa-2x'></span>
</button>
<ul id='ul'></ul>