代码语法高亮放前端还是后端?

本贴最后更新于 2048 天前,其中的信息可能已经时移世易

目前主流(比如 GitHub)的做法是在后端高亮,输出带样式类的 HTML;其他也有在前端通过 JS 语法高亮库进行处理的。

后端渲染语法高亮的优势是:

  • 不会“闪”一下,渲染效果更平滑
  • 统一处理,多端场景下升级方便

当然,也有缺点:

  • 消耗服务器资源,请求的整体响应时间变长
  • 处理稍微复杂,如果某种语言没有后端高亮库,就只能通过其他的高亮进程处理

我比较倾向于后端渲染,能一次做完的事情就不要分布出去了,那样有点浪费资源。

大家觉得哪种方案好?

单选 公开 永不结束 28 票
前端渲染
35% 10 票
后端渲染
64% 18 票

  • 语法高亮
    2 引用 • 32 回帖
  • 后端
    44 引用 • 126 回帖 • 1 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    245 引用 • 1338 回帖 • 1 关注
1 操作
88250 在 2019-08-27 20:15:36 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • dengwentong 1

    @88250 @Vanessa
    居然说到,前端和后端,自然 D & V 。
    个人倾向后端。
    作为自身,后端操作比较友好;作为看客,前端有基本的语法高亮应该看起来也会友好吧。😄

  • betou

    倾向于后端,有需求直接改就完了,如果是个 APP,出问题还要重新打包上架。

  • betou 1

    对现代硬件来说,那一丢丢资源不算是资源吧,当前情况应该是代码发展速度跟不上硬件的发展速度

  • InkDP via Linux

    后端,作为刚开发玩皮肤的人来说 后端会让前端很舒服

  • someone27889 via macOS

    看后端提供的服务类型吧?如果后端都是数据交换数据处理那么 渲染 放在前端合适,如果后端有一部分前端渲染引擎的话,那就放后端。

    1 回复
  • 个人倾向放后端,代码高亮是通用的逻辑,可以一次开发,多处使用

  • Vanessa via macOS

    做为前端,总担心辣么多的处理后端会吃不消。

  • jeffjade

    看应用场景;放在前端,倘若处理得当,可以不显现“闪”一下;一般处理的话,那一闪而过的瞬间,应该也不太影响使用体验。

    对很多静态网站生成器而言,不需要后台的话,则也无需内置,用户可按需载入高亮库,这也是如今个人博客处理办法;如 Ghost:https://quickapp.lovejade.cn/how-to-elegantly-handle-quickapp-request/

    对于当下流行使用 MVVM 框架来搭建的单页应用(SPA),首屏渲染、SEO 的解决之道,可以有很多法子,可不采取服务端渲染这种相对更复杂方法,那么高亮这种自然也还是前端自己处理(发布前预渲染,这种也算是在前端了吧)。

    1 回复
  • 88250

    场景是 HTML 渲染,比如帖子里有代码块时需要高亮。

    发这个帖的原因是最近正在做社区 Markdown 渲染改造,以前用的是 markdown-it+ highlight.js(两个项目都是 JavaScript 的),目前正在改造为 Lute + Chroma(两个项目都是 golang 的)。因为我这边还有其他项目也有这个需求,所以和大家讨论一下看看,是否还有什么我没有考虑到的情况,集思广益 🙏

  • 88250

    嗯,还是看应用场景。

    Go 实现的一个静态站点生成系统 Hugo 用的也是 Chroma,这也算是“预渲染”操作吧 😅

    2 回复
  • Sunnnner via macOS

    前端吧- -后端主要还是负责数据,因为我就是负责数据的别的还没到达那种地步,另外如果放在后端,服务器一定要 hold 住,不然崩了怎么办

  • yixiangblog

    直接 highlight.js 呗。用国内 cdn,印象中不会闪,用起来也方便,也可以不用管后端是啥语言写的。if it ain't broken, don't fix it.

  • someone27889 via macOS

    V 说怕你吃不消,那就前端渲染?

    1 回复
  • jeffjade

    嗯嗯,是的。

  • 88250

    没事,我吃得消 doge

    @Vanessa

  • krbtgt

    后端想为前端分担压力,前端担心后端吃不消。

    我怀疑你们俩在撒狗粮,并且我有证据 😂

  • zonghua

    当然是前端啦,减少我后端工作量,上班多摸鱼

    1 回复
  • csfwff 1

    huaji 当然是后端啦,减少我前端工作量,上班多摸鱼

    1 回复
  • zonghua

    工作成果我收了哈

  • 2501224066

    前端只会调接口,给他搞不放心

  • jenphyjohn 1 via macOS

    这狗粮我先干了!后端统一处理易于维护,但是增加服务端渲染时间,看如何取舍了。个人倾向前端处理,能提高一丁点儿的体验效果也是好的,前提是有方法能解决闪一下的问题。

  • zwxbest 1

    前端啊,渲染这种功能放前端,可以减轻服务器压力,同时前端调试也比较方便。

  • Blackman99 1

    如果可以的话不必限制在一端,两种方式都提供,使用者可以根据具体应用场景进行选择

  • K 1

    对与这种,不影响使用的优化项 在前端处理也算是一种边缘计算,这个的优点大家也都清楚。

    如果放到后端处理,
    对于少量用户来说 貌似也没有什么不可以〜
    但是稍稍多一点儿,就要用更多的 money(服务器)来换取用户体验来,简直不要太划算。

    但是这个时候,出与前端的求生欲: 我还是要说,支持后端渲染 +1 trollface

  • PeterChu 1

    我的想法是,这种问题应该不是简单一元一次方程,而应该是多元的,也就是说决定最终取舍的影响因素应该有多个,不同的影响因素大小下会产生不同的最终结果。所以,就这个问题可能需要考虑有几个,一个是服务器的能力,一个是访问量,一个是时间。🤔

  • jeffjade

    这类帖子,社区的投票功能蛮有使用的必要,:)。

    1 回复
  • 88250

    嗯嗯。

    @participants 大家来投票吧!

请输入回帖内容 ...

推荐标签 标签

  • 旅游

    希望你我能在旅途中找到人生的下一站。

    93 引用 • 901 回帖
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    66 引用 • 114 回帖 • 196 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    199 引用 • 541 回帖 • 1 关注
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    366 引用 • 1842 回帖 • 2 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖 • 2 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 652 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3195 引用 • 8215 回帖
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 542 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 3 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    53 引用 • 40 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    693 引用 • 537 回帖
  • 996
    13 引用 • 200 回帖 • 6 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 1 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 384 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    239 引用 • 224 回帖 • 1 关注
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 543 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 147 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 318 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    729 引用 • 1278 回帖 • 1 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖 • 1 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    168 引用 • 595 回帖
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 83 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    31 引用 • 108 回帖