Typecho-Joe主题实现图片评论功能
Typecho-Joe主题实现图片评论功能
2022-08-10 / 31评论 / 7,032阅读 / 9点赞
-- XG.孤梦

Typecho-Joe主题实现图片评论功能

XG.孤梦
2022-08-10 / 31 评论 / 7,032 阅读 / 正在检测是否收录...

实现效果

实际使用效果见本站,主题将在1.1.7版本中嵌入此功能,但是在开启前需要配置一些东西。
使用我的主题模板搭建好图床直接把js里的图床API改成自己的就可以了

效果图

默认状态

47472-d5xmnhvoam.png

已选择文件

55325-akyk21pgzd6.png

点击插入 上传图片
  • 默认插入Markdown语法链接,目的方便实现评论点击图片大图预览效果

41426-51r9oq426iv.png

开启判断文件类型
  • 在js中加入后缀判断文件类型,选择非图片类型时,会提示

47599-ewvo5o9yqew.png


准备

修改后台设置

1.首先进入Typecho后台,找到评论设置开启评论Markdown语法。

2.只开启Markdown语法是不够的,因为评论区默认禁用HTML标签,所以要添加允许的HTML标签。
在评论设置的最下方找到允许使用的HTML标签和属性,插入以下代码。

<img src="" data-original="" width="">
<a href="" data-fancybox="">

如果还想在评论区播放视频,自行查看网站的video标签和属性值一同加入进去。

注意
  • 因为解除了a标签后可以写入JS脚本语句,造成安全隐患,强烈建议开启主题设置里的禁止使用JS脚本评论。

3.图床API接口,推荐自己搭建。
可以使用我源码库中的外链网盘源码搭建,我的博客使用的也是这个源码的API,为了减轻服务器负担我加了域名验证,我的接口只允许了本站,要是实在不会动手可以打赏,请我喝一杯奶茶,我开放你的域名授权,不过还是建议自己搭建,因为方便自己管理上传上来的文件。

使用本主题1.1.7之后版本只需要在主题文件夹的根目录下的js文件夹里找到img.js,打开找到图床API把链接换成自己的接口链接就可以正常使用了。


实现

修改functions.php

在合适位置插入以下代码,其他的joe主题自行修改 setAttribute(); 中加入的属性。

    $JCommentImg = new Typecho_Widget_Helper_Form_Element_Select(
        'JCommentImg',
        array('off' => '关闭(默认)', 'on' => '开启'),
        'off',
        '是否开启评论图片功能',
        '介绍:开启后,评论区域可以选择图片进行评论'
    );
    $JCommentImg->setAttribute('class', 'j-setting-content j-setting-other');
    $form->addInput($JCommentImg->multiMode());

修改评论区文件 comment.php

找到评论区文件,我的主题是在主题文件根目录下的 pblic/comment.php

插入以下代码到图片位置,或者合适位置。

20277-5euzdfiu4vf.png

找到输出评论的div标签,添加 id=markdown 的属性,不同的主题markdown解析的id可能不同,可以进入文章按f12,找到文章的父标签查看。

13811-n0lxqtkxxgl.png


添加css文件 btn.css

美化上传和插入按钮,可根据喜好自己修改或者加入样式,创建好文件后复制下方代码粘贴保存即可,并在head.php或者header.php中引入文件。

.file {
    position: relative;
    display: inline-block;
    background: #D0EEFF;
    border: 1px solid #99D3F5;
    border-radius: 4px;
    padding: 4px 5px;
    overflow: hidden;
    height: 32px;
    color: #1E88C7;
    text-decoration: none;
    text-indent: 0;
    line-height: 18px;
}
.file input {
        position: absolute;
        font-size: 100px;
        right: 0;
        top: 0;
        opacity: 0;
}
.file:hover {
        background: #AADFFD;
        border-color: #78C3F3;
        color: #004974;
        text-decoration: none;
}
.xgimg{
    display: flex;
    align-items: center;
    justify-content: flex-end;
}
.xgimg button {
    background: var(--classD);
    padding: 0 15px;
    height: 32px;
    border: none;
    font-size: 13px;
    transition: all 0.35s;
    color: var(--main);
}
.xgimg button:active {
    color: #fff;
    background: var(--theme);
}
.showFileName{
    width:40%;
    font-size: 12px;
    text-align: right;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
@media screen and (max-width: 768px){
    .showFileName{
    width:0px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
}

创建js文件 img.js

创建文件,复制下方代码粘贴,然后把图床API接口改成自己的,如果使用其他的图床接口,请根据接口的开发文档,使用
formData.append(); 方法添加需要的参数即可,修改好后,在footer.php中引入文件,并且在它的上方 axios.min.js 因为上传使用的是axios方式请求。

<script type="text/javascript" src="https://unpkg.com/axios@0.27.2/dist/axios.min.js"></script>

最后,再后台开启评论图片功能,清除缓存刷新页面,图片上传按钮就出现了,附一张评论图片成功的评论截图

05672-v9zy25z0g7o.png


9

评论 (31)

取消
  1. 头像
    123456
    中国–四川–遂宁 电信 · Windows 10 · Google Chrome

    哈哈哈

    回复
  2. 头像
    1
    中国–湖北–宜昌 电信 · Android · Google Chrome

    看看

    回复
  3. 头像
    O泡
    中国–北京–北京 联通 · Windows 10 · Google Chrome

    看看

    回复
  4. 头像
    1111
    中国–四川–德阳 电信 · Windows 10 · Google Chrome

    1111

    回复
  5. 头像
    学习
    中国–湖南 移动/全省通用 · Windows 10 · Google Chrome

    111

    回复
  6. 头像
    枫叶
    中国–香港 腾讯云 · Android · Google Chrome

    能改成上传到后台本地服务器上吗表情

    回复
  7. 头像
    火喵
    中国–辽宁–大连 鹏博士宽带 · Windows 10 · Google Chrome

    呜呜呜,要是网盘支持七牛就好了

    回复
    1. 头像
      XG.孤梦 作者
      中国–湖南–长沙 联通 · Android · Google Chrome
      @ 火喵

      可以自己改下接口和参数就行,其他网盘不稳定,图片容易失效,不如自己搭的所以没搞

      回复
      1. 头像
        看看
        中国–广东–深圳 电信 · iPhone · Safari
        @ XG.孤梦
        该回复疑似异常,已被系统拦截!
        回复
  8. 头像
    中国–四川–成都 电信 · Windows 10 · Google Chrome

    表情

    回复
  9. 头像
    s1240
    中国–重庆–重庆 联通 · Windows 7 · Google Chrome

    看视频来了

    回复
  10. 头像
    s1240
    中国–重庆–重庆 联通 · Windows 7 · Google Chrome

    安装主题后,有插入图片按钮,但是图片评论不成功,是要按照大佬的这篇文章修改啊 ?

    回复
    1. 头像
      XG.孤梦 作者
      中国–湖南–长沙 联通 · Android · Google Chrome
      @ s1240

      是的,因为默认用的我的图床接口,我限制了域名,所以需要自己搭一个图床网盘,设置完Typecho评论,把img.js文件里的API接口换掉就行

      回复
      1. 头像
        lifetech
        中国–福建–厦门 移动 · Android · Google Chrome
        @ XG.孤梦

        有些复杂

        回复
      2. 头像
        s1240
        中国–重庆–重庆 联通 · Windows 7 · Google Chrome
        @ XG.孤梦

        谢谢,大佬,摸索中

        回复