通过JS动态追加标签,以父评论子评论为例
以下代码前后端交互以Django模板语法为例
先来以伪代码来示意用法:
HTML部分:

JS动态插入部分代码:

运行之后我们来浏览器看检查打印的内容:

看插入前后打印结果我们可以得知
$title[0].innerHTML = $title.html() + '<p>嘿嘿</p>';
这一句只是在原标签内部追加了一个
<p>嘿嘿</p>
原理解析:
$title.html()获取到了<tr>标签内部所有标签及文本,拿到的是字符串格式
然后让它+一个p标签,然后将相加后的整体重新加入到<tr>标签内部
innerhtml是原生JS的方法,它区别于innertext,innerhtml可以识别插入内容中的html标签
innertext会将插入内容当文本插入。
下面我们来看JS动态将子评论插入父评论下面显示的例子:
页面效果:

一个父评论为作为一楼展示,子评论都展示在父评论下面。
渲染思路:
1、父评论由页面加载时以模板渲染的方式加载和渲染
2、子评论在JS中定义一个function f(){},定义后直接f()调用,作用是向后端发送ajax请求,获取到所有子评论。
3、将子评论跟根据父评论id动态插入到父评论后面
首先看一篇文章父评论渲染HTML代码:

待渲染的子评论字符串代码:

JS渲染的完整代码:
function f() {
$.ajax({
url: '/get_son_token/',
type: 'post',
data: {
'csrfmiddlewaretoken': '{{ csrf_token }}',
'code': 'get_son_token',
'article_id': $("#id_article").val()
},
success: function (data) { //data为后端返回的子评论数据,格式为:{'code':200,'msg':[子评论1,子评论2,子评论3...]}
console.log(data.msg); //子评论是一个个字典{'id':10,'create_time':'2019-06-22 22:12:12','parent_id':5,'user__usrname':'egon','user_id':'2','parent_user_username':'dxx'}
$.each(data.msg, function (index, obj) {
let id = obj.id;
let content = obj.content;
let create_time = obj.create_time;
let parentId = '#' + obj.parent_id;
let username = obj.user__username;
let user_id = obj.user_id;
let parent_username = obj.parent__user__username;
//一条待插入的回复记录
str = `<div><p>
<a href='/${username}/'>${username}</a>
回复: <a href="/${parent_username}/">${parent_username}</a> <span>${create_time}</span>
<span>
<a class='replay' username=${username} parent_id=${id}>回复</a>
<a class='cite' content=${content}>引用</a>
</span>
</p>
<p>内容: <span>${content}</span></p>
<div id="${id}"></div>
</div>`;
//$(parentId).html()取到所有上一级评论内部html及文本
//与新插入的记录相加后再覆盖原标签内部所有html及文本
$(parentId)[0].innerHTML = $(parentId).html() + str;
})
}
})
}
f(); //页面加载即调用
Django后端为ajax提供数据的代码:
import datetime
def get_son_token(request):
if request.POST.get('code') == 'get_son_token':
#取出所有该文章下的子评论
token_list = models.Token.objects.exclude(parent_id=None).filter(article_id=request.POST.get("article_id")).values('id',
'user__username','parent_id','create_time','content','user_id','parent__user__username')
token_list = [dict(obj) for obj in token_list] for obj in token_list:
obj['create_time'] = obj['create_time'].strftime("%Y-%m-%d %X")
#obj: {'id': 23, 'user__username': 'kevin', 'parent_id': 13, 'create_time': '2019-06-24 22:49:32', 'content': '你又在拍马屁dxx', 'user_id': 39, 'parent__user__username': 'dxx'}
back_dic = {'code': 200, "msg": token_list}
return JsonResponse(back_dic)
数据库存储结构:
parent_id为自关联字段,article_id为文章外键关联,user_id为当前评论人(外键)

通过JS动态追加标签,以父评论子评论为例的更多相关文章
- js|jq获取兄弟节点,父节点,子节点
08.19自我总结 js|jq获取兄弟节点,父节点,子节点 一.js var parent = test.parentNode; // 父节点 var chils = test.childNodes; ...
- js动态追加的元素如何触发事件
一般通过js或者jQuery动态添加的元素标签,通过该元素标签.class.id触发事件,是无效的.如下所示: <body> <input type="text" ...
- JS获取节点的兄弟,父级,子级元素的方法(js获取子级获取到换行与空格元素-FF)
先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比. JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当最DOM元素 < ...
- js动态插入标签代码(insertAdjacentHTML)
做网页时通过ajax请求获取到数据后,有的需要把数据拼接到带有各种标签的字符串中,拼接完字符串就需要把字符串动态添加到网页上的某个位置,举个
- js 面向对象 动态添加标签
有点逻辑 上代码 thml布局 点击查看代码 <!DOCTYPE html> <html lang="en"> <head> <meta ...
- 通过JS动态的修改HTML元素的样式和增添标签元素等
一. 通过JS动态的修改HTML元素的样式 1. 要想在js中动态的修改HTML元素的样式,首先需要写document, document我们称之为文档对象,这个对象中保存了当前网页中所有的 ...
- easyui 如何为标签动态追加属性实现渲染效果
简述一下在项目遇到的问题,这边有一个需求,选择不同类型,加载不同的div标签(其中属性是否必填是区分类型的关键) html界面是这样的 <div class="grid_1 lbl&q ...
- JS动态添加的标签无法绑定事件解决方案~~~
今天用ajax实现动态插入数据时发现监听一直不起作用,一样的代码,非动态的就可以监听实现 这是困扰了我近一个小时的bug,后面才理解到可能是动态插入导致的! 看了看网上的解决方案,似乎都不太通俗,讲的 ...
- 为什么JS动态生成的input标签在后台有时候没法获取到
最近在做一个产品添加的功能,需求有点奇葩,所以在添加的时候免不了要用到动态生成控件,然后我就使用了JS去动态生成一些 checkbox类型的input标签,在以前用asp.net在后台生成的input ...
随机推荐
- ELK---- kibana 安装 学习
我已经安装了java环境,和elasticsearch.这只有存储,那么管理界面工具什么的,目前还没有,我就是用kibana进行安装. Kibana是一个开源的分析和可视化平台,设计用于和Elasti ...
- 多线程爬取猫眼电影TOP100并保存到mongo数据库中
import requests import re import json from requests.exceptions import RequestException from multipro ...
- CKEditor5 输入文字时拼音和汉字同时输入问题
在使用 CKEditor5 + vue 时,出现输入文字时,拼音和文字一起输入到编辑器到问题.与之前项目中使用 ckeditor 的区别是,这次项目是在 python 架构下局部引入 ckeditor ...
- 004_FreeRTOS创建与删除任务
(一)创建与删除任务函数 (二)上面的四个函数目前只用动态创建任务和删除任务 (三)动态创建任务 函数 xTaxkCreate() 1. 宏 configSUPPORT_DYNAMIC_ALLOCAT ...
- learning armbian steps(5) ----- armbian 构建arm rootfs
基于learning armbian step(4) 的总结,我们来实践一下,接下来的会把整个构建的log都贴出来: vmuser@vmuser-virtual-machine:~/qemu-arm$ ...
- CSP-S模拟测试69 题解
一如既往的垃圾,又回到了那个场场垫底的自己,明明考场上都想到正解了,但是就是拿不到分,可能是互奶把rp用光了吧以后一定加强训练代码能力. T1: 考场上一直yy矩阵快速幂,虽然自己矩阵快速幂一点都不会 ...
- 【luoguSP3267】--莫队,不同数字个数
题意翻译 给出一个长度为n 的数列,a1 a2 ,...an ,有q 个询问,每个询问给出数对(i,j),需要你给出ai ai+1 ,...,aj 这一段中有多少不同的数字 题目 ...
- Luogu5369 [PKUSC2018]最大前缀和
题目链接:洛谷 题目大意:给定一个长为$n$的整数序列,求全排列的最大前缀和(必须包含第一个数)之和. 数据范围:$1\leq n\leq 20,1\leq \sum_{i=1}^n|a_i|\leq ...
- Try-Catch-Finally代码块中的return
测试类的原型是这样子的 public class TryCatchFinallyToReturn { public static void main(String[] args) { System.o ...
- 2019.7.9 校内测试 T1挖地雷
这一次是交流测试?边交流边测试(滑稽 挖地雷 这个题是一个递推问题. 首先我们看第一个格子,因为它只影响了它的上面和右上面这两个地方是否有雷. 我们可以分3种情况讨论: 1. 第一个格子的数字是2: ...