Typecho 增加固定字段

方法一

 

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

 

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

<p class="mono url-slug">
    <label for="slug" class="sr-only"><?php _e('网址缩略名'); ?></label>
    <?php echo preg_replace("/\{slug\}/i", $input, $permalink); ?>
</p>

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

<p>
    <label for="text" class="sr-only"><?php _e('文章内容'); ?></label>
    <textarea style="height: <?php $options->editorSize(); ?>px" autocomplete="off" id="text" name="text" class="w-100 mono"><?php echo htmlspecialchars($post->text); ?></textarea>
</p>

 

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

/**
    * 发布文章
    *
    * @access public
    * @return void
    */
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->time : $content['created'],
        'modified'      =>  $this->options->time,
        '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');
}

 

使用方法:

在后台编辑文章页面添加字段内容

主题下的 post.php 添加如下即可

<?php $this->test_url(); ?>

 

posted @ 2020-04-01 21:53  letleon  阅读(797)  评论(0编辑  收藏  举报