我有添加新评论的代码,但是“回复评论”功能无法正常工作。如果我在单击reply()
时推送表单添加评论,然后仅在现有评论的内部/下方添加五次。
这是我的代码:
HTML:
<div class="comments-app" ng-app="addCommentsApp" ng-controller="AddCommentsController as commCtrl">
<div class="comments">
<div class="comment" hide-me="5000" ng-repeat="comment in commCtrl.comments | orderBy: 'date'">
<div class="comment-box">
<div class="comment-footer">
<div class="comment-info">
<span class="comment-date">{{ comment.date | date: 'medium' }}</span>
</div>
<div class="comment-actions">
<a ng-click="reply()">Reply</a>
</div>
</div>
<div class="comment-text">{{ comment.text }}</div>
</div>
</div>
</div>
<!-- From -->
<div class="comment-form">
<form class="form" name="form" ng-submit="form.$valid && commCtrl.addComment()" novalidate>
<div class="form-row">
<textarea
class="input"
ng-model="commCtrl.comment.text"
placeholder="Add comment..."
required></textarea>
</div>
<div class="form-row">
<input type="submit" value="SEND">
</div>
</form>
</div>
</div>
JavaScript:
(function(){
'use strict';
var myApp = angular.module('addCommentsApp', []);
myApp.controller('AddCommentsController', AddCommentsController);
// Inject $scope dependency.
AddCommentsController.$inject = ['$scope', '$timeout'];
// Declare AddCommentsController.
function AddCommentsController($scope, $timeout) {
var vm = this;
// Current comment.
vm.comment = {};
// Array where comments will be.
vm.comments = [];
// Fires when form is submited.
vm.addComment = function() {
// Add current date to the comment.
vm.comment.date = Date.now();
vm.comments.push( vm.comment );
vm.comment = {};
// Reset clases of the form after submit.
$scope.form.$setPristine();
}
}
})();
CSS:
.comment-form .form .input{
background-color: #fcfcfc;
border: none;
border-radius: 4px;
box-shadow: 0 1px 1px rgba(0, 0, 0, .15);
color: #555f77;
font-family: inherit;
font-size: 14px;
padding: 5px 10px;
outline: none;
width: 100%;
}
.comment-form .form textarea.input{
height: 100px;
padding: 15px;
}
.comment-form .form input[type=submit]{
background-color: #555f77;
border: none;
border-radius: 4px;
box-shadow: 0 1px 1px rgba(0, 0, 0, .15);
color: #fff;
cursor: pointer;
display: block;
margin-left: auto;
outline: none;
padding: 6px 15px;
}
.comment-form .form .input.disabled {
background-color: #E8E8E8;
}
.comment-form,
.comment{
margin-bottom: 20px;
position: relative;
z-index: 0;
}
.comment .comment-box{
background-color: #fcfcfc;
border-radius: 4px;
box-shadow: 0 1px 1px rgba(0, 0, 0, .15);
margin-left: 100px;
min-height: 60px;
position: relative;
padding: 15px;
}
.comment .comment-box:before,
.comment .comment-box:after{
border-width: 10px 10px 10px 0;
border-style: solid;
border-color: transparent #FCFCFC;
content: "";
left: -10px;
position: absolute;
top: 20px;
}
.comment .comment-box:before{
border-color: transparent rgba(0, 0, 0, .05);
top: 22px;
}
.comment .comment-footer:after{
content: "";
display: table;
clear: both;
}
.comment .comment-footer a{
color: #acb4c2;
text-decoration: none;
}
.comment .comment-footer a:hover{
color: #555f77;
text-decoration: underline;
}
.comment .comment-info{
float: left;
width: 85%;
}
.comment .comment-date:before{
content: "|";
margin: 0 10px;
}
.comment-actions{
float: left;
text-align: right;
width: 15%;
}
https://jsfiddle.net/kurzalowski/eefyap1y/也有一个小提琴
最佳答案
您可以将addComment
更改为:
vm.addComment = function(oldComment) {
if (oldComment !== undefined) {
oldComment.comment.date = Date.now();
if (!oldComment.comments) {
oldComment.comments = [];
}
oldComment.comments.push({
text: oldComment.comment.text,
date: oldComment.comment.date
});
} else {
// Add current date to the comment.
vm.comment.date = Date.now();
vm.comments.push(vm.comment);
vm.comment = {};
}
// Reset clases of the form after submit.
$scope.form.$setPristine();
因此结构将是:
[
{
"text": "sdsd",
"date": 1504440173932,
"showReply": true,
"comment": {
"text": "aaaaa2",
"date": 1504440258984
},
"comments": [
{
"text": "aaaaa",
"date": 1504440176459
},
{
"text": "aaaaa2",
"date": 1504440258984
}
]
}
]
Demo Fiddle
完整的HTML
<div class="comments-app" ng-app="addCommentsApp" ng-controller="AddCommentsController as commCtrl">
<div class="comments">
<div class="comment" hide-me="5000" ng-repeat="comment in commCtrl.comments | orderBy: 'date'">
<div class="comment-box">
<div class="comment-footer">
<div class="comment-info">
<span class="comment-date">{{ comment.date | date: 'medium' }}</span>
</div>
<div class="comment-actions">
<a href="" ng-click="commCtrl.reply(comment)">Reply</a>
<div ng-if="comment.showReply">
<div class="comment" hide-me="5000" ng-repeat="subcomment in comment.comments | orderBy: 'date'">
<p>{{subcomment.text}}</p>
</div>
<form class="form" name="form" ng-submit="form.$valid && commCtrl.addComment(comment)" novalidate>
<div class="form-row">
<textarea class="input" ng-model="comment.comment.text" placeholder="Add comment..." required></textarea>
</div>
<div class="form-row">
<input type="submit" value="SEND">
</div>
</form>
</div>
</div>
<div class="comment-text">{{ comment.text }}</div>
</div>
</div>
</div>
<!-- From -->
<div class="comment-form">
<form class="form" name="form" ng-submit="form.$valid && commCtrl.addComment()" novalidate>
<div class="form-row">
<textarea class="input" ng-model="commCtrl.comment.text" placeholder="Add comment..." required></textarea>
</div>
<div class="form-row">
<input type="submit" value="SEND">
</div>
</form>
</div>
</div>