【PHP7版本】Typecho网址分类导航主题TiNav

【PHP7版本】Typecho网址分类导航主题TiNav

TiNav分类导航主题改自molerose,感谢原作者Simon.Xiong.本屌不玩github,所以主题下载直接放在博客上。

由于Typecho中某些自定义字段不支持PHP7版本,所以这次在2.0最终版的基础上更新PHP7版本,安装方法较复杂,不建议小白使用,小白请移步 完善版

如果网站LOGO还是无法使用,请在sidebar中写入绝对链接,懒得修改了。

演示

本主题涉及到修改Typecho系统文件和数据库,注意备份,建议看完本文再操作,莫着急。

使用方法:

1、下载主题,上传到typecho主题文件夹;

2、在Typecho数据库文章表中添加新字段

在数据表 typecho_contents 中新建一个 test_url、test_word、test_img 三个字段,类型可为字符串;

数据库

3、修改Typecho系统文件(不爱动手的小伙伴可以下载下面修改好的系统文件,直接覆盖。)

点击下载

直接覆盖的小伙伴请忽略下面的步骤,直接跳到 创建导航栏

①后台模板文件 admin/write-post.php 表单中(大概在第21行后面)插入:

<p>
跳转链接:<input type="text" name="test_url" value="<?php $post->test_url(); ?>"/>
链接描述:<input type="text" name="test_word" value="<?php $post->test_word(); ?>"/> 
链接LOGO:<input type="text" name="test_img" value="<?php $post->test_img(); ?>"/>
</p>

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

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

③在 var/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'],
            'test_word'         =>  empty($content['test_word']) ? NULL : $content['test_word'],
            'test_img'         =>  empty($content['test_img']) ? NULL : $content['test_img']
        );

在 update 函数里构建更新结构加入新字段:

   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'],
            'test_word'     =>  empty($content['test_word']) ? NULL : $content['test_word'],
            'test_img'      =>  empty($content['test_img']) ? NULL : $content['test_img']
        );

在 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','table.contents.test_word','table.contents.test_img')->from('table.contents');
}

上面步骤操作完成后,撰写文章页面如下图
文章页面
到这里主题安装完毕。

创建导航栏

关于导航栏的创建,只要新建分类即可

导航栏标题前面的图标请在分类缩略名中填入,图标样式请参考
http://fontawesome.dashgame.com/
分类

为了不打击本屌的开发积极性,转载请注明出处.

如果喜欢,在下面留个言呗.

The end.

最后修改:
赞赏支持
最大的开心,莫过于你请我吃辣条

已有 39 条评论

  1. 077 077 1天前

    我的网站LOGO还是无法使用,如何在sidebar中写入绝对链接
    这个sidebar是什么?

  2. Lengsir Lengsir 12天前

    加了,就是test_url、test_word、test_img这三个字段,长度500,50,500,类型都是varchar,文件也替换了,然后每次创建文章都出现Database Query Error

    1. SEOGO运营狗 SEOGO运营狗勃主 12天前

      把所有设置后之后,先不要安装links插件,先发文章

      1. Lengsir Lengsir 12天前

        现在解决了,但是安装links插件后会不会还会变成这样?

        1. SEOGO运营狗 SEOGO运营狗勃主 12天前

          我这边测试过是没问题的,不知是不是links版本问题

          1. Lengsir Lengsir 12天前

            好像是links的问题,我安装了就会出现错误,我的版本是1.1.1,请问博主用的是哪一版本的links

            1. SEOGO运营狗 SEOGO运营狗勃主 12天前

              跟你一样版本,那就不知道是啥问题了

              1. SEOGO运营狗 SEOGO运营狗勃主 12天前

                这个还真没试过

              2. Lengsir Lengsir 12天前

                会不会是typecho的版本问题啊?我的版本有点旧1.0-14.10.10

    2. SEOGO运营狗 SEOGO运营狗勃主 12天前

      使用默认主题也有问题,应该是数据库有问题,建议重装typecho,把网站数据库清理一遍,一步步来

    3. SEOGO运营狗 SEOGO运营狗勃主 12天前

      后台方不方便发给我

      1. Lengsir Lengsir 12天前

        给你admin@mail.seogo.me发邮件了,不知道你收不收得到。

        1. SEOGO运营狗 SEOGO运营狗勃主 12天前

          收到,稍等

  3. Lengsir Lengsir 13天前

    照你这么改完后新建文章出现这个Database Query Error,咋办?

    1. SEOGO运营狗 SEOGO运营狗勃主 12天前

      数据库加表了吗?

  4. Jun Jun 17天前

    先感谢博主, 安装PHP7版本后,使用手机端点解左边导航栏报错,, 好像是关于next() 这个函数的

    1. SEOGO运营狗 SEOGO运营狗勃主 17天前

      已修复,重新下载主题覆盖

      1. Jun Jun 17天前

        好的,谢谢

  5. Xiaole Xiaole 18天前

    重新编译了PHP5。。。(๑•́ ₃ •̀๑)

    1. SEOGO运营狗 SEOGO运营狗勃主 18天前

      忘记1.0版本支持PHP7了,记性不好

  6. chris_wong chris_wong 20天前

    收藏,谢谢( ̄ε(# ̄) Σ

  7. 楠尘 楠尘 34天前

    站长您好,前台发表文章时候,那三个字段无法写入数据库是怎么回事呢,只有手写数据酷就正常

    1. 楠尘 楠尘 33天前

      有增加啊,前台写不了数据到那三个字段

      1. SEOGO运营狗 SEOGO运营狗勃主 33天前

        你应该加错了,不应该用不了的,挺多人在用

    2. SEOGO运营狗 SEOGO运营狗勃主 34天前

      在数据库中增加三个字段,文章中有讲到

  8. Alone88 Alone88 34天前

    高大上,想试一试 哈哈

  9. ixinqiu ixinqiu 36天前

    感觉棒棒的试试看

  10. 随风 随风 37天前

    it is wonderful,感谢博主分享

    1. SEOGO运营狗 SEOGO运营狗勃主 37天前

      谢谢支持