typecho文章点击插入全部附件,详细研究

本文阅读 3 分钟
广告

一个可能有点鸡肋的功能,反正一般情况是用不上吧,但是排除特殊的情况,比如需要大量文件上传的时候,一个一个的插入确实太慢了,所以还是需要类似的处理机制。好吧,真实原因是一个QQ好友需要,而且对方催了很多天,让我完全无法划水摸鱼,所以抽空做了出来。严格来说还是很简单的,就是不熟悉typecho的文件对应功能,所以找不到修改实现的地方,现在倒也是解决了问题。
总之,其实对研究typecho的文件输出模式,还是很有帮助吧。

timg (1).jpg

控制附件上传的功能在admin/file-upload.php

循环输出代码如下:

<?php while ($attachment->next()): ?>
    内部代码
<?php endwhile; ?>

相关标签:

<?php $attachment->cid(); ?>   附件ID
<?php echo $attachment->attachment->url; ?>  附件详细路径
<?php echo $attachment->attachment->isImage ? 1 : 0; ?>    附件是否为图片
<?php $attachment->title(); ?>   附件名称
?php echo number_format(ceil($attachment->attachment->size / 1024)); ?>   附件大小/单位KB

理解以上的东西后,看看默认附件插入是怎样的。
QQ截图20190629133420.png

是不是很明了了,就是把标签和这些字符组合,再套进循环就好了,不过它是分为两个部分的,所以需要拆分开来,这里我定义了两个js字段,并且把标签套了进去,n代表空格。

var filename="<?php while ($attachment->next()): ?>[<?php $attachment->title(); ?>][<?php $attachment->cid(); ?>]\n<?php endwhile; ?>";
var fileurl="<?php while ($attachment->next()): ?>\n  [<?php $attachment->cid(); ?>]: <?php echo $attachment->attachment->url; ?><?php endwhile; ?>";

有了内容,开始插入
写一个js方法,读取文本框里面的内容,然后把之前字段的内容追加上去。

function filetext(){
    var text = document.getElementById("text");
    text.innerHTML = text.innerText+filename+fileurl;
}

写个a标签或者按钮调用这个方法,我懒得继续美化了。

<div class="full" style="width:100%;text-align:center;">
    <a href="javascript:;" onclick="filetext();">全部插入</a>
</div>

总之,上述都弄完后,file-upload.php里面代码是这样的
1.png

然后,看看实际效果吧。
2.png

文件下载:

规则之树版权所有,转载请注明来源,标明作者及原文链接

本文来自投稿,不代表本站立场,如若转载,请注明出处:https://www.ruletree.club/archives/1324/
[授权转载]《木卫二往事》第三话 阴谋
« 上一篇 06-24
不知不觉,到雅加达第三天了
下一篇 » 07-12
广告

发表评论

V注册会员 L评论等级
R36 条回复
  1. xzzLv.1 说道:
    2022-05-13     MacOS /    Chrome

    大佬,插入图片的额外判断该怎么加

  2. sensiribbedLv.1 说道:
    2022-03-17     Win 10 /    Chrome

    大佬好
    感谢大佬的分享啊

  3. sensiribbedLv.1 说道:
    2022-03-17     Win 10 /    Chrome

    大佬好
    感谢大佬的分享啊

  4. TristeD9VLv.1 说道:
    2022-01-15     Android /    Chrome

    点击全部插入后,会新打开一个空白的标签页,没用

    1. 不暇VLv.6 说道:
      2022-01-15     Win 7 /    Chrome

      @TristeD9

      这里你要注意,插入图片和普通附件的区别,需要去额外加一个判断

      1. xzzLv.1 说道:
        2022-05-13     MacOS /    Chrome

        @不暇

        大佬...被这个判断难住了,要插入图片怎么额外加啊

        1. 不暇VLv.6 说道:
          2022-05-13     Android /    Chrome

          @xzz

          你可以观察一下,typecho插入图片的代码是什么,并且默认的文件循环标签里,会有一个字段做判断的。

  5. TristeD9Lv.1 说道:
    2022-01-15     Android /    Chrome

    这个很不错,经常会用到也

  6. 一二三四Lv.1 说道:
    2021-11-28     Win 10 /    QQ浏览器

    全部插入 无反应 保存后编辑可以用 咋处理

    1. 不暇VLv.6 说道:
      2021-11-29     Android /    Chrome

      @一二三四

      这个只能自己分析下页面结构再尝试了

  7. 一二三四Lv.1 说道:
    2021-11-27     Win 10 /    QQ浏览器

    这回复了也没看到文件

    1. 不暇VLv.6 说道:
      2021-11-27     Android /    Chrome

      @一二三四

      可能是缓存问题……其实靠文章里的内容也足够了,没必要下载文件

  8. sensiLv.1 说道:
    2021-11-24     Win 10 /    Chrome

    阿巴阿巴

  9. 111xxLv.1 说道:
    2021-07-16     Win 10 /    Chrome

    为什么我回复了

  10. 俊宏Lv.1 说道:
    2021-06-02     Win 10 /    Chrome

    w为什么我回复了 还是看不到下载地址啊

  11. 月影楼兰VLv.1 说道:
    2021-06-01     MacOS /    Chrome

    好人啊

  12. 俊红Lv.1 说道:
    2021-05-30     Win 10 /    Chrome

    正需要

    1. 俊红Lv.1 说道:
      2021-05-30     Win 10 /    Chrome

      @俊红

      希望可以快点审核通过,急需哈哈哈

  13. 啊蕾蕾Lv.1 说道:
    2021-04-29     Win 10 /    Chrome

    阿巴阿巴

  14. 小软妹Lv.1 说道:
    2020-11-20     Win 7 /    Chrome

    666,大佬。

  15. xyzLv.1 说道:
    2020-09-10     Win 10 /    Chrome

    看看好不好用.

没有更多评论了

作者信息

热门文章

标签TAG

热评文章