热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

我写的这段把对象数据变为DOM节点的代码该怎么优化?

简单介绍下思路: ajax到对象,然后从子到父依次创建对象,设置样式,添加层级。然后代码长这样:1234567891011121314151617181920212223242526272829303

简单介绍下思路:
ajax到对象,然后从子到父依次创建对象,设置样式,添加层级。
然后代码长这样:



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
function Activity(obj) {

  var activityCOntent= document.createElement('a');

  activityContent.innerHTML = obj.post.c;

  activityContent.className = 'activity-content';

  activityContent.style.overflow = 'hidden';

  activityContent.href = '/t/'+obj.tid+'#'+obj.pid;

  var activityTitleText = document.createElement('span');

  activityTitleText.innerHTML = obj.oc.t;

  activityTitleText.style.overflow = 'hidden';

  var activityTitle = document.createElement('div');

  activityTitle.className = 'activity-title';

  var activityTitleA = document.createElement('a');

  activityTitleA.appendChild(activityTitleText);

  activityTitleA.href = '/t/'+obj.tid;

  var activityInfo = document.createElement('span');

  activityInfo.className = 'activity-info';

  if(obj.forum) {

    var color = obj.forum.color || 'orange';

    var forum = document.createElement('a');

    forum.href= '/f/'+obj.fid;

    var forumText = document.createElement('span');

    forumText.className = 'activity-title-forum';

    forumText.style.backgroundColor = color;

    forumText.innerHTML = ' '+obj.forum.abbr+' ';

    forum.appendChild(forumText);

    activityTitle.appendChild(forum);

  }

  if(obj.toMyForum) {

    var color = obj.toMyForum.color || 'orange';

    var toMyForum = document.createElement('a');

    toMyForum.href= '/m/'+obj.toMyForum._key;

    var toMyForumText = document.createElement('span');

    toMyForumText.className = 'activity-title-forum';

    toMyForumText.style.backgroundColor = color;

    toMyForumText.innerHTML = ' '+obj.toMyForum.abbr+' ';

    toMyForum.appendChild(toMyForumText);

    activityTitle.appendChild(toMyForum);

  }

  if(obj.myForum) {

    var color = obj.myForum.color || 'orange';

    var myForum = document.createElement('a');

    myForum.href= '/m/'+obj.myForum._key;

    var myForumText = document.createElement('span');

    myForumText.className = 'activity-title-forum';

    myForumText.style.backgroundColor = color;

    myForumText.innerHTML = ' '+obj.myForum.abbr+' ';

    myForum.appendChild(myForumText);

    activityTitle.appendChild(myForum);

  }

  activityTitle.appendChild(activityTitleA);

  activityInfo.appendChild(activityTitle);

  activityInfo.appendChild(activityContent);

  var activityUser = document.createElement('div');

  activityUser.className = 'activity-user';

  activityUserA = document.createElement('a');

  activityUserA.href = '/activities/'+obj.uid;

  var activityUserAvatar = document.createElement('img');

  activityUserAvatar.className = 'activity-user-avatar';

  activityUserAvatar.src = '/avatar/'+ obj.uid;

  activityUserA.appendChild(activityUserAvatar);

  var username = document.createElement('a');

  username.href = '/activities/'+obj.uid;

  username.innerHTML = obj.user.username;

  activityUser.appendChild(activityUserA);

  activityUser.appendChild(username);

  var type;

  switch (obj.type) {

    case 1:

      type = 'Po';

      break;

    case 2:

      type = 'Re';

      break;

    case 4:

      type = 'Rc';

      break;

    default:

      type = 'X';

  }

  var activityType = document.createElement('div');

  activityType.className = 'activity-type';

  var activityTypeText = document.createElement('div');

  activityTypeText.className = 'activity-type-text';

  activityTypeText.innerHTML = type;

  var activityTypeDate = document.createElement('div');

  activityTypeDate.className = 'activity-type-date';

  activityTypeDate.innerHTML = moment(obj.time).fromNow();

  activityType.appendChild(activityTypeText);

  activityType.appendChild(activityTypeDate);

  var activity = document.createElement('div');

  activity.className = 'activity';

  activity.appendChild(activityType);

  activity.appendChild(activityUser);

  activity.appendChild(activityInfo);

  return activity;

}

就这种玩意儿。。。咋优化呢?
前端对ES6的支持不理想,所以字符串模板不能用,又不好添加框架,硬写的话,应该怎么做?
这样写对比字符串拼接然后直接innerHTML有什么劣势?


   



推荐阅读
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • switch语句的一些用法及注意事项
    本文介绍了使用switch语句时的一些用法和注意事项,包括如何实现"fall through"、default语句的作用、在case语句中定义变量时可能出现的问题以及解决方法。同时也提到了C#严格控制switch分支不允许贯穿的规定。通过本文的介绍,读者可以更好地理解和使用switch语句。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • 本文介绍了贝叶斯垃圾邮件分类的机器学习代码,代码来源于https://www.cnblogs.com/huangyc/p/10327209.html,并对代码进行了简介。朴素贝叶斯分类器训练函数包括求p(Ci)和基于词汇表的p(w|Ci)。 ... [详细]
  • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
  • 本文介绍了Foundation框架中一些常用的结构体和类,包括表示范围作用的NSRange结构体的创建方式,处理几何图形的数据类型NSPoint和NSSize,以及由点和大小复合而成的矩形数据类型NSRect。同时还介绍了创建这些数据类型的方法,以及字符串类NSString的使用方法。 ... [详细]
  • 本文介绍了DataTables插件的官方网站以及其基本特点和使用方法,包括分页处理、数据过滤、数据排序、数据类型检测、列宽度自动适应、CSS定制样式、隐藏列等功能。同时还介绍了其易用性、可扩展性和灵活性,以及国际化和动态创建表格的功能。此外,还提供了参数初始化和延迟加载的示例代码。 ... [详细]
  • 第8章 使用外部和内部链接
    8.1使用web地址LearnAboutafricanelephants. ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
author-avatar
mobiledu2502856963
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有