前言

刚用开源UOJ搭建OJ成功时就想在导航栏那里添加一个站内页面链接,无奈当时乱搞水平低,网上也没有教程,不晓得怎么弄

今天突然来了闲情乱搞一通,结果还真乱搞成了...特意写下为后来人少走点弯路

前置技能点

  • Linux基本命令行操作

如果您觉得这篇文章很naiive,请谅解,因为我对前端一无所知,也是以这样的视角写一份教程

假设我们要在导航栏加一个叫NCOD的站内链接,并创建一个叫NCOD的站内页面

Step1

先找个地方把当前版本用SVN检出,如果您不知道这是什么船新操作,建议您仔细阅读文档中对SVN的介绍

注意在这里SVN地址后还要加/uoj,例如svn co svn://xxx.xxx.x.x/uoj ...

然后cd uoj/1/app

Step2

首先cd views,然后看到一个叫main-nav.php的玩意没,sudo gedit main-nav.php(如果你是V党请自便)

然后你就会看到一大串导航栏中已经有的链接名字的英文,比如hack,contests之类的,你只要仿造格式复制一句话加在后面就好了,比如

<li><a href="/NCOD"><?= UOJLocalde::get('NCOD') ?></a></li>

这时候你把文件提交到SVN仓库(如果您不知道这是什么,请您还是阅读文档 中对SVN的介绍),会发现导航栏多了个叫NCOD的链接,但是点进去却是404,接下来我们就要创建一个叫NCOD的界面

Step3

cd ..\app目录,再cd controllers,会发现有一大堆php,这时候只要在这里新建个php文件就行了,例如

gedit NCOD.php,里面的内容也是有讲究的,例如

<?php echoUOJPageHeader(UOJLocale::(get('NCOD')))?>
<article>
<header>
<h2 class="page-header">National Coming Out Day</h2>
<header>
...
<article>
<?php echoUOJPageFooter() ?>

注意第一行中括号内容要一致,如果您没有把握,您可以复制faq.php的格式看一看

保存修改后你需要将这个文件加到SVN仓库

例如svn add NCOD.php

Step4

创建php文件后再cd ..\app目录

看到一个叫route.php的玩意没?sudo gedit route.php

仿照格式加一句话就好了,例如

Route::any('/NCOD','NCOD.php');

然后保存修改后再cd /locale/basic,修改zh-cn.php,仿照格式在其中加上导航栏中你想要的中文名字

例如'NCOD' => '出柜日',

Step5

最后回到\app文件夹,将这个版本提交上仓库即可

svn commit -m "..." *

话说距离初赛还有2天还在搞这个幺蛾子,怕是要凉了

在开源UOJ的导航栏中添加新页面链接的更多相关文章

  1. magento导航栏中如何加入home主页

    magento在导航栏中加入home主页是很简单的,几个步骤即可在magento导航栏中加入home主页! 下面简单介绍下如何在magento导航栏中加入home主页: 首先我们打开对应应用的模板文件 ...

  2. AngularJS 导航栏动态添加.active

    在传统jQuery中,实现导航栏动态添加.active类的思路比较简单,就是当点击的时候,清除其他.active,然后给当前类加上.active. 但是在AngularJS中,就不能再采用这种jQue ...

  3. 利用overflow实现导航栏中常 出现的倒三角下拉小图标

    常用网页界面中,导航栏中的倒三角下拉小图标实现,可用overflow: 效果如右图: .Triangle{position:relative;width:280px;height:15px;} ;ov ...

  4. 【代码笔记】iOS-在导航栏中显示等待对话框

    一,效果图. 二,代码. ViewController.m #import "ViewController.h" @interface ViewController () @end ...

  5. window10删除导航栏中的onedrive

    前面介绍了如何删除导航栏中的“快速访问”,对于一个根本用不着的“oneDrive”肯定也得搞掉. 0.处理前: 1.卸载onedrive是不能清除导航栏里面的onedrive的,进入注册表regedi ...

  6. bootstrap如何去除自带的样式----导航栏中的菜单实现平滑的过渡到对应的菜单区域-------动态跟换模态框中的内容

    问题1:如何去除bootstap中css中自带的overflow:hidden这个样式 今天遇见在bootstap中轮播图上的  附带图  片不能够显示出来,图片始终有一部分的高度  被隐藏了 后来通 ...

  7. JavaScript网站设计实践(二)实现导航栏当前所选页面的菜单项高亮显示

    一.(一)中的代码还可以修改的地方. 在(一)中,如果是运行在服务器下,如apache等,可以把head和navigation的div抽取出来,放置在另一个html文件里,然后在页面中,include ...

  8. phpcms 内容——>评论管理 中添加 打开文章链接的 功能

    需要实现的功能:在后台管理系统中的 内容 下的——>评论管理  中添加 打开文章链接的 功能 1.数据库表是 v9_comment和v9_comment_data_1. v9_comment是被 ...

  9. 向CDH5集群中添加新的主机节点

    向CDH5集群中添加新的主机节点 步骤一:首先得在新的主机环境中安装JDK,关闭防火墙.修改selinux.NTP时钟与主机同步.修改hosts.与主机配置ssh免密码登录.保证安装好了perl和py ...

随机推荐

  1. delphi10.3.1不支持.net 5

    delphi10.3.1不支持.net 5 安装DELPHI的前提条件:WINDOWS必须安装有.NET. DELPHI安装程序在安装的时候会自动检测.NET是否已经安装好,如果发现没有,它会报错,并 ...

  2. Linux通过AIO进行异步读文件

    下面列出源代码: #include <stdio.h> #include <stdlib.h> #include <string.h> #include <a ...

  3. post请求导出Excel表格

    axios.interceptors.response.use((response) =>{ if(response.config && response.config.resp ...

  4. 17 Flutter仿京东商城项目 保存历史搜索记录 删除历史记录 清空历史记录 长按删除

    Storage.dart import 'package:shared_preferences/shared_preferences.dart'; class Storage{ static Futu ...

  5. Qt编写数据可视化大屏界面电子看板9-曲线效果

    一.前言 为了编写数据可视化大屏界面电子看板系统,为了能够兼容Qt4和嵌入式linux系统,尤其是那种主频很低的,但是老板又需要在这种硬件上(比如树莓派.香橙派.全志H3.imx6)展示这么华丽的界面 ...

  6. 【ARTS】01_25_左耳听风-201900429~20190505

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  7. C# 实现启用或停止本地网络连接

    获取本机网络连接列表 public static List<string> GetNetList() { List<string> ls = new List<strin ...

  8. springboot-定时任务-多线程

    1.配置异步线程池 import java.util.concurrent.Executor; import org.springframework.context.annotation.Bean; ...

  9. 计算1+2+...+n

    牛客上面一道题,闲来无事做做陶冶情操. 这一陶冶还真的陶冶出了骚操作 看一下题目吧: 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字及 ...

  10. elasticsearch启动日志报错not enough master nodes discovered during pinging (found [[]], but needed [-1]), pinging again

    排查步骤 逻辑上讲是,一个节点去ping  master节点,结果却没有得到回应,多次重试依旧失败.应该重点观察: 1.master启动后,IP是否可以有防火墙权限,设置防火墙规则或则直接关闭防火墙 ...