首页>建站相关>如何为Typecho后台编辑器添加一个自定义按钮

如何为Typecho后台编辑器添加一个自定义按钮

写了一个自用的小鸟主题,主页与分类页基本都定稿了,但是single页面的内容部分感觉过于单一,就想着是不是可以利用markdown加入类名。但尝试了很多网上的方案,hyperdown(typecho的markdown解析器)都无法正常解析。

于是转而考虑直接写入html语句的方式,为编辑器添加几个按钮,以含类名的html方式一些不同的类名,根据类名实现不同的视觉效果。比如利用"single-jplink"类名实现了下面这样一个按钮效果,链接指向joe主题的《自定义后台编辑器功能》,这也是本文的参考。

Typecho自定义后台编辑器功能

修改编辑的大致原理是通过插件语法在文章或页面的编辑页插入一段js,利用js添加按钮并绑定动作,首先在function.php里加入如下代码,这段代码会在页面编辑以及文章编辑页时在末尾插入一段js代码,代码的路径可以自行定义,博主把它暂时放在了主题的js文件夹里,就是代码中的“/js/editor.js”:

/*========
后台编辑器
========*/
Typecho_Plugin::factory('admin/write-post.php')->bottom = array('Editor', 'edit');
Typecho_Plugin::factory('admin/write-page.php')->bottom = array('Editor', 'edit');

class Editor{
  public static function edit(){
    echo "<script src='" . Helper::options()->themeUrl . '/js/editor.js' . "'></script>";
  }
}

然后将命名为editor.js代码放入主题的js文件夹,js全文如下:

(function ($) {
  $(document).on('DOMContentLoaded', function(){
    const items=[
      {
        title:'下载',
        id:'wmd-dllink-button',
        class:'single-dllink'
      },
      {
        title:'跳转',
        id:'wmd-jplink-button',
        class:'single-jplink'
      },
    ];
    items.forEach(function(item){
      let element= $(`<li class="wmd-button" id="${item.id}" title="${item.title}">${item.title}</li>`); 
      element.on('click',function(){
        $('#text').toggleSelection(item.class);        
      });
      $('#wmd-button-row').append(element);
    });  
  });

  $.fn.extend({
    toggleSelection: function (a) {
      this.focus();
      let selected=document.getSelection();
      let result=selected.toString();
      if(result.length==0)return;
      let pattern=/<a class="(.*?)" href="(.*?)" rel="nofollow" target="_blank">(.*?)<\/a>/;
      let before=`<a class="${a}" href="(.*?)" rel="nofollow" target="_blank">`;
      let after='</a>'
      if(pattern.exec(result)){
        if(pattern.exec(result)[1]==a){
          selected.focusNode.children[1].setRangeText(pattern.exec(result)[3]+"||"+pattern.exec(result)[2]);
        }else{
          selected.focusNode.children[1].setRangeText(result.replace(pattern.exec(result)[1],a));
        } 
      }else{
        selected.focusNode.children[1].setRangeText(before.replace('(.*?)',result.split('||')[1])+result.split('||')[0]+after);
      }
    }
  });
})(jQuery);

程序实现了这样一个功能,将“aa||bb”格式的数据通过正则匹配,分别将aa作为a标签的内容,将bb填入元素的href。成功生成后,在选区未被变更的情况下,如果再次点击按钮,则让选区恢复为原值,如果想要更换为另一个类,则直接点击一下另一个按钮即可。

为了这个小功能看了整整两天的代码,但最后发现理想丰满但现实过于骨感,默认的编辑器不处理(即直接输出html)的标签极为有限,印象中仅有“ul|table|pre|a”等标签以及一些格式控制标签(比如加粗斜体等)会被正确处理为html元素,其他的大多会被一对双引号打回原形,成了单纯的字符。所以最终只实现了对于链接的类区分,利用不同的类对a标签实现了不同的样式。

一点补充

学习过程中发现,对于其他元素的支持,可以通过修改HyperDown.php文件的方式来扩展,但是,这种方式可能在升级程序后失效,感觉缺乏一些兼容性,而且更换其他主题后,很可能导致页面上出现多余的html标签,修改方法请点击上方链接查看。

增加HTML标签支持

标签: typecho

移动端可扫我直达哦~

推荐阅读

typecho 2025-04-29

typecho让后台设置的代码更为易读

利用deepseek写一个简单的后台控件类,来简化一下后台的书写,利用这个类,我们可以把参数以数组的形式组装在一起,由类来轮询读取并生成控件。一个简单的后台实现类if (!class_exists('Aug_Config')) { ...

建站相关 typecho

typecho 2025-04-20

关于typecho主题的目录结构

wordpress的极简主题需要有两个文件,分别是index.php以及style.css,而在typecho中,因为主题的一些配置信息默认被放在了index.php而不是style.css文件中,所以直接往主题包里仍一个index....

建站相关 typecho

typecho 2025-04-20

从零开始做一个 Typecho 主题系列

Typecho是一款轻量级、高效的开源博客程序,由国内开发者团队开发维护。它采用PHP语言编写,支持MySQL、SQLite等多种数据库,安装包体积仅有500KB左右,运行时内存占用极低,却能提供出色的性能表现。这款博客程序最大的特点...

建站相关 typecho

typecho 2025-04-18

Typecho_Db 类以及各方法基础用例

Typecho_Db 是 Typecho 博客系统的数据库操作核心类,提供了数据库连接、查询构建和执行等功能。Typecho_Db 提供了简洁高效的数据库操作接口,是Typecho插件和主题开发中最常用的类之一。主要功能数据库连接管理...

建站相关 typecho

typecho 2025-04-16

typecho 1.2.1 给标签添加description说明文字

之前写过一篇为typecho标签添加说明字段的方法,对应的是typecho1.1版本,目前typecho的稳定版本是1.2.1, 因为服务器php版本较低,一直没有去尝试新版。这几天用小皮面板搭建了一个本地的php环境,终于是正经尝试...

建站相关 typecho

typecho 2025-04-11

Typecho博客系统中的config.inc.php文件

在 Typecho 博客系统中,config.inc.php 是一个核心配置文件,用于存储数据库连接信息和系统关键设置。它通常位于 Typecho 的安装根目录下,在安装过程中自动生成。Typecho 的安装包解压后并不包含这个文件,...

建站相关 typecho

typecho 2025-04-09

Typecho尝试获取主题的一些基础信息

在Typecho的主题一览里是利用了一个循环来遍历主题,遍历主题的时候可以通过activated参数来确定是否是当前主题,这样就可以利用官方提供的函数来获取主题信息了,缺点很明显,需要多使用一个循环,浪费资源。<?php \Wi...

建站相关 typecho

typecho 2025-04-02

typecho模板解析优先级

类似于wordpress ,Typecho的模板系统也遵循特定的优先级规则,当系统寻找模板文件时会按照以下顺序进行查找:模板文件查找优先级主题自定义模板 (最高优先级)usr/themes/[主题名]/[模板文件]例如:usr/the...

建站相关 typecho

typecho 2025-03-27

typecho如何实时更新被修改后的style.css文件

给新的站点“biib.top”加了个友情链接,顺便修改了一下主题的footer背景。但浏览器缓存了站点的css文件,修改后的效果并不实时生效。直接清除浏览器缓存是个简单粗暴的办法,问题在于这个效果也只是针对博主个人,用户可不会没事瞎清...

建站相关 typecho

typecho 2024-04-20

typecho根据标签的slug name信息判断是否输出免责声明

博主是从事机械行业的,工作过程中接触了很多二手老旧的设备,因为是二手设备,不缺胳膊少腿能正常运行已是难得,完善的说明书与售后服务想都不要想了。所以找设备的说明书成了一项附加的工作,总得让设备正常运行起来,偶尔设备有个小病小痛的,也不能...

建站相关 typecho

typecho 2023-11-02

Typecho开发文档-Widget设计文档

什么是WidgetWidget是组成Typecho的最基本元素,除了已经抽象出来的类库外,其它几乎所有的功能都会通过Widget来完成.在实践中我们发现,在博客这种小型但很灵活的系统中实施一些大型框架的思想是不合适的,它会使系统灵活性...

建站相关 typecho