• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Adding a Comment
2
3
4After a user enters a comment and clicks the submit button, the content is displayed in the comment area. The user can click the delete button to delete the current comment and enter another comment again.
5
6
7To set such a comment area on a page, you need to associate a click event with **\<div>**, **\<text>**, and **\<input>**. You can use the **\<input>** component to obtain the comment entered by a user, use the **\<text>** component to display the comment, and use commentText to mark the **\<text>** component (controlled by the if attribute). Associate the click event with the **\<text>** component that contains Done and Delete to update the **commentText** and **inputValue**. The following is an example:
8
9```html
10<!-- xxx.hml -->
11<div class="container">
12  <text class="comment-title">Comment</text>
13  <div if="{{!commentText}}">
14    <input class="comment" value="{{inputValue}}" onchange="updateValue()"></input>
15    <text class="comment-key" onclick="update" focusable="true">Done</text>
16  </div>
17  <div if="{{commentText}}">
18    <text class="comment-text" focusable="true">{{inputValue}}</text>
19    <text class="comment-key" onclick="update" focusable="true">Delete</text>
20  </div>
21</div>
22```
23
24
25```css
26/* xxx.css */
27.container {
28  margin-top: 24px;
29  background-color: #ffffff;
30}
31.comment-title {
32  font-size: 40px;
33  color: #1a1a1a;
34  font-weight: bold;
35  margin-top: 40px;
36  margin-bottom: 10px;
37}
38.comment {
39  width: 550px;
40  height: 100px;
41  background-color: lightgrey;
42}
43.comment-key {
44  width: 150px;
45  height: 100px;
46  margin-left: 20px;
47  font-size: 32px;
48  color: #1a1a1a;
49  font-weight: bold;
50}
51.comment-key:focus {
52  color: #007dff;
53}
54.comment-text {
55  width: 550px;
56  height: 100px;
57  text-align: left;
58  line-height: 35px;
59  font-size: 30px;
60  color: #000000;
61  border-bottom-color: #bcbcbc;
62  border-bottom-width: 0.5px;
63}
64```
65
66
67```js
68// xxx.js
69export default {
70  data: {
71    inputValue: '',
72    commentText: false,
73  },
74  update() {
75    this.commentText = !this.commentText;
76  },
77  updateValue(e) {
78    this.inputValue = e.text;
79  },
80}
81```
82