Typecho二次开发 文章表添加新字段

有时候我们需要在博客中显示其他功能比如每篇文章可以自定义标题颜色,就需要添加一个标题颜色属性,就必须添加自定义的字段,我这里是添加了一个比如

1.首先数据表 typecho_contents 中新建一个test_url字段,类型可为字符串。

2.后台模板文件write-post.php 表单中插入:

<p><input type="text" name="test_url" value="<?php $post->test_url(); ?>"/></p>

3.在 Widget\Contents\Post\Edit.php 这里的 writePost 函数里需要接收新字段参数:

 public function writePost()
    {
        $contents = $this->request->from('password', 'allowComment',
            'allowPing', 'allowFeed', 'slug', 'tags', 'text', 'visibility','test_url');

4.1 Widget\Abstract\Contents.php 这里的 insert 函数添加新参数:

    /**
     * 插入内容
     *
     * @access public
     * @param array $content 内容数组
     * @return integer
     */
    public function insert(array $content)
    {
        /** 构建插入结构 */
        $insertStruct = array(
            'title'         =>  empty($content['title']) ? NULL : htmlspecialchars($content['title']),
            'created'       =>  empty($content['created']) ? $this->options->gmtTime : $content['created'],
            'modified'      =>  $this->options->gmtTime,
            'text'          =>  empty($content['text']) ? NULL : $content['text'],
            'order'         =>  empty($content['order']) ? 0 : intval($content['order']),
            'authorId'      =>  isset($content['authorId']) ? $content['authorId'] : $this->user->uid,
            'template'      =>  empty($content['template']) ? NULL : $content['template'],
            'type'          =>  empty($content['type']) ? 'post' : $content['type'],
            'status'        =>  empty($content['status']) ? 'publish' : $content['status'],
            'password'      =>  empty($content['password']) ? NULL : $content['password'],
            'commentsNum'   =>  empty($content['commentsNum']) ? 0 : $content['commentsNum'],
            'allowComment'  =>  !empty($content['allowComment']) && 1 == $content['allowComment'] ? 1 : 0,
            'allowPing'     =>  !empty($content['allowPing']) && 1 == $content['allowPing'] ? 1 : 0,
            'allowFeed'     =>  !empty($content['allowFeed']) && 1 == $content['allowFeed'] ? 1 : 0,
            'parent'        =>  empty($content['parent']) ? 0 : intval($content['parent']),
            'test_url'         =>  empty($content['test_url']) ? NULL : $content['test_url']
        );

4.2 这里的update函数里构建更新结构加入新字段,:

    /**
     * 更新内容
     *
     * @access public
     * @param array $content 内容数组
     * @param Typecho_Db_Query $condition 更新条件
     * @return integer
     */
    public function update(array $content, Typecho_Db_Query $condition)
    {
        /** 首先验证写入权限 */
        if (!$this->isWriteable(clone $condition)) {
            return false;
        }
        /** 构建更新结构 */
        $preUpdateStruct = array(
            'title'         =>  empty($content['title']) ? NULL : htmlspecialchars($content['title']),
            'order'         =>  empty($content['order']) ? 0 : intval($content['order']),
            'text'          =>  empty($content['text']) ? NULL : $content['text'],
            'template'      =>  empty($content['template']) ? NULL : $content['template'],
            'type'          =>  empty($content['type']) ? 'post' : $content['type'],
            'status'        =>  empty($content['status']) ? 'publish' : $content['status'],
            'password'      =>  empty($content['password']) ? NULL : $content['password'],
            'allowComment'  =>  !empty($content['allowComment']) && 1 == $content['allowComment'] ? 1 : 0,
            'allowPing'     =>  !empty($content['allowPing']) && 1 == $content['allowPing'] ? 1 : 0,
            'allowFeed'     =>  !empty($content['allowFeed']) && 1 == $content['allowFeed'] ? 1 : 0,
            'parent'        =>  empty($content['parent']) ? 0 : intval($content['parent']),
            'test_url'         =>  empty($content['test_url']) ? NULL : $content['test_url'],
        );

4.3 select函数里添加查询新字段:

/**
     * 获取查询对象
     *
     * @access public
     * @return Typecho_Db_Query
     */
    public function select()
    {
        return $this->db->select('table.contents.cid', 'table.contents.title', 'table.contents.slug', 'table.contents.created', 'table.contents.authorId',
        'table.contents.modified', 'table.contents.type', 'table.contents.status', 'table.contents.text', 'table.contents.commentsNum', 'table.contents.order',
        'table.contents.template', 'table.contents.password', 'table.contents.allowComment', 'table.contents.allowPing', 'table.contents.allowFeed',
        'table.contents.parent','table.contents.test_url')->from('table.contents');
    }

这样就能自由扩展Typecho的文章表字段了。


相关文章

已有 11 条评论

  1. 我用的typecho,学习了

  2. Yang Yang

    这个方法好~ 赞~

  3. 学习了!

  4. 没注意要用 , 结束,然后直接白了,检查了一遍才发现,后面要改的兄弟注意哦。

  5. icon_surprised.png 这个666
    回头有空试试

  6. 这里请教一个比较弱的问题
    比如我要设置一个图标,但是如果有一篇文章我没有设置图标
    这个时候我想输出的时候如果有图片输出图标,如果没有图标输出一张预先设定的图标

    这个时候应该如何做?

  7. 码怪 码怪

    icon_cry.png 您好!按照您的步骤来,后台文章不能显示,编辑一片空白!,也加了,还是空白!求解!谢谢!

    1. 仔细检查一遍吧,标点什么的,别用中文标点。不行恢复。

  8. 有没有办法让这些字段可以被站内搜索检索到字段内的内容

添加新评论

icon_redface.pngicon_smile.pngicon_biggrin.pngicon_mrgreen.pngicon_question.pngicon_sad.pngicon_exclaim.pngicon_surprised.pngicon_eek.pngicon_confused.pngicon_cool.pngicon_lol.pngicon_mad.pngicon_wink.pngicon_arrow.pngicon_cry.png