20241127 给typecho文章编辑附件 添加视频 图片预览

Typecho在写文章时,如果一次性上传太多张图片可能分不清哪张,因为附件没有略缩图,无法实时阅览图片,给文章插入图片时很不方便。

编辑admin/file-upload.php

大约十八行的位置

一个while 循环里面,这是在进行html元素更新操作,在合适的位置插入视频或者图片标签即可.

最终成为这样

复制代码
<?php while ($attachment->next()): ?>
    <li data-cid="<?php $attachment->cid(); ?>" data-url="<?php echo $attachment->attachment->url; ?>" data-image="<?php echo $attachment->attachment->isImage ? 1 : 0; ?>"><input type="hidden" name="attachment[]" value="<?php $attachment->cid(); ?>" />
    
    <!-- 视频,图片预览 -->
    <?php if($attachment->attachment->isImage==1): ?>
    <img src="<?php echo $attachment->attachment->url; ?>" width="80%"></src><br/>
    <?php endif; ?>
    <?php if ($attachment->attachment->mime == "video/mp4"): ?>
    <video src="<?php echo $attachment->attachment->url; ?>" width="100%" controls="true"></video><br/>
    <?php endif; ?>

    <a class="insert" title="<?php _e('点击插入文件'); ?>" href="###"><?php $attachment->title(); ?></a>
        <div class="info">
            <?php echo number_format(ceil($attachment->attachment->size / 1024)); ?> Kb
            <a class="file" target="_blank" href="<?php $options->adminUrl('media.php?cid=' . $attachment->cid); ?>" title="<?php _e('编辑'); ?>"><i class="i-edit"></i></a>
            <a href="###" class="delete" title="<?php _e('删除'); ?>"><i class="i-delete"></i></a>
        </div>
    </li>
<?php endwhile; ?>

当然仅仅是这里还不够,还有admin/file-upload-js.php需要修改,原理差不多

大约103行,额外追加一点代码

复制代码
function fileUploadComplete (id, url, data) {
    let media = ''
    if(data.type==="png"){
        media=' <img src='+data.url+' width="80%"></src><br/>'
    }else if(data.type==="mp4"){
       media=' <video src='+data.url+' width="80%" controls="true"></video><br/>'
    }
    var li = $('#' + id).removeClass('loading').data('cid', data.cid)
        .data('url', data.url)
        .data('image', data.isImage)
        .html('<input type="hidden" name="attachment[]" value="' + data.cid + '" />'
        + media
            + '<a class="insert" target="_blank" href="###" title="<?php _e('点击插入文件'); ?>">' + data.title + '</a><div class="info">' + data.bytes
            + ' <a class="file" target="_blank" href="<?php $options->adminUrl('media.php'); ?>?cid=' 
            + data.cid + '" title="<?php _e('编辑'); ?>"><i class="i-edit"></i></a>'
            + ' <a class="delete" href="###" title="<?php _e('删除'); ?>"><i class="i-delete"></i></a></div>')
        .effect('highlight', 1000);
        
    attachInsertEvent(li);
    attachDeleteEvent(li);
    updateAttacmentNumber();

    if (!completeFile) {
        completeFile = data;
    }
}
相关推荐
laocaibulao5 小时前
mac电脑composer命令如何指定PHP版本
macos·php·composer
zz-zjx5 小时前
云原生LVS+Keepalived高可用方案(二)
开发语言·php·lvs
网络精创大傻5 小时前
PHP 与 Node.js:实际性能对比
开发语言·node.js·php
KevinLyu5 小时前
PHP内核详解· 内存管理篇(七)· 调整内存块大小
php
hj10439 小时前
php上传企业微信附件的方法
开发语言·php·企业微信
游九尘9 小时前
在 PHP 中打印数据(调试、输出内容)
php
深圳市恒讯科技11 小时前
使用站群服务器做SEO,如何避免被搜索引擎判定为“站群作弊”?
服务器·搜索引擎·php
APIshop13 小时前
代码实战:PHP爬虫抓取信息及反爬虫API接口
开发语言·爬虫·php
一直向钱14 小时前
基于你的 SRS 直播流煤体配置(通过 http_hooks 回调实现鉴权),结合 TP6 框架,以下是完整的 PHP SDK 封装方案
网络协议·http·php
技术小丁14 小时前
使用 PHP 和 PhpSpreadsheet 在 Excel 中插入图片(附完整代码)
后端·php