- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
恐怕我真的不知道如何做到这一点 - 我想在 Gitlab Wiki 页面中使用变量。这可能使用html吗?我可以在页面上运行脚本吗?
例如,这个 question在 html 中使用 javascript 变量 - 这样的事情可能吗?
对于我的具体示例,我想要一个带有表格的页面,其中第一列是数字,并且我想取最大值并将其显示在页面顶部。因此,例如该表可能有如下行:
1 X
22 Y
15 Z
最佳答案
您的 Wikipage 中不能有脚本,因为它们会清理 HTML(查看它们允许的内容 here )。为了做你想做的事,你可以在 Gitlab-CI 中生成该页面作为项目部署管道的一部分,使用任何渲染引擎并将该变量放入其中,并使用 Gitlab's Wiki APIs 自动更新它.
如何
我创建了一个演示 NodeJS 项目 here ,当我推到 master
分支,自动生成 Wiki pages .您可以查看代码以了解其工作原理。
这个示例应用程序公开了一个函数来获取水果和库存数量的列表。我们会自动将这些数据添加到 Wiki 中。
第 1 步 - 创建页面模板
您可以为您的项目添加 Wiki 页面的模板。在我的示例中,我使用了 MustacheJS .我把所有东西都放在 wiki
文件夹(参见步骤 5 末尾的文件夹结构)。您的模板可能如下所示:
维基/模板/home.mst
# Welcome to the supermarket
The biggest quantity we have in stock is for **{{topProduct.label}}**,
with a total of **{{topProduct.stock}}**!
| Fruit | Quantity |
|-----------|--------------|
{{#inventory}}
| {{label}} | {{stock}} |
{{/inventory}}
在此示例中,数据将来自项目代码本身。
Note: The scripts I wrote as a demo use
axios
to make requests to the Gitlab API,mustache
to render the pages, andqs
to format the data as a query string before posting it to Gitlab. You can use other ones or install them as dev dependencies:npm install --save-dev axios mustache qs
build
目录。像这样的东西:
const fs = require('fs');
const Mustache = require('mustache');
const myApp = require('../src/index.js');
const inventory = myApp.getInventory();
// Get the Mustache template
const homeTemplate = fs.readFileSync(__dirname + '/templates/home.mst', 'utf-8');
// Get the fruit with the highest quantity
const topProduct = inventory.reduce((acc, curr) => {
if (acc === null || curr.stock > acc.stock) {
return curr;
} else {
return acc;
}
}, null);
// Render the page using your variables
const homeContent = Mustache.render(homeTemplate, { inventory, topProduct });
// Write the file in a build directory
const buildDir = __dirname + '/../build';
if (!fs.existsSync(buildDir)) {
fs.mkdirSync(buildDir);
}
fs.writeFileSync(buildDir + '/home.md', homeContent);
在您的
package.json
,添加一个命令来运行该脚本:
"scripts": {
// ...
"wiki:build": "node wiki/build.js"
}
第 3 步 - 部署您的 Wiki 页面
const fs = require('fs');
const Axios = require('axios');
const qs = require('qs');
const config = {
gitlabBaseUrl: 'https://gitlab.com', // Update this if you're on a private Gitlab
projectId: process.env.CI_PROJECT_ID, // Provided by Gitlab-CI
privateToken: process.env.WIKI_DEPLOY_TOKEN, // Added through Gitlab interface
buildDir: __dirname + '/../build'
};
const axios = Axios.create({
baseURL: config.gitlabBaseUrl,
headers: { 'Private-Token': config.privateToken, Accept: 'application/json' }
});
(async function deploy() {
const existingPages = await getExistingWikiPages();
const updatedPages = getUpdatedPages();
// Pages which existed but are no longer in the build (obsolete)
const pagesToDelete = existingPages.filter(p1 => updatedPages.every(p2 => p2.slug !== p1.slug));
// Pages which didn't exist before
const pagesToCreate = updatedPages.filter(p1 => existingPages.every(p2 => p2.slug !== p1.slug));
// Pages which already exist
const pagesToUpdate = updatedPages.filter(p1 => existingPages.some(p2 => p2.slug === p1.slug));
console.log(
`Found ${pagesToDelete.length} pages to delete, ${pagesToCreate.length} pages to create, ${pagesToUpdate.length} pages to update.`
);
for (let page of pagesToDelete) {
await deletePage(page);
}
for (let page of pagesToCreate) {
await createPage(page);
}
for (let page of pagesToUpdate) {
await updatePage(page);
}
console.log('Deploy complete!');
})();
function getExistingWikiPages() {
return axios.get(`/api/v4/projects/${config.projectId}/wikis`).then(res => res.data);
}
function getUpdatedPages() {
const files = fs.readdirSync(config.buildDir);
return files.map(file => {
const name = file // Remove the file extension
.split('.')
.slice(0, -1)
.join('.');
return {
format: 'markdown', // You could make this depend on the file extension
slug: name,
title: name,
content: fs.readFileSync(`${config.buildDir}/${file}`, 'utf-8')
};
});
}
function deletePage(page) {
console.log(`Deleting ${page.slug}...`);
return axios.delete(`/api/v4/projects/${config.projectId}/wikis/${page.slug}`);
}
function createPage(page) {
console.log(`Creating ${page.slug}...`);
return axios.post(`/api/v4/projects/${config.projectId}/wikis`, qs.stringify(page));
}
function updatePage(page) {
console.log(`Updating ${page.slug}...`);
return axios.put(`/api/v4/projects/${config.projectId}/wikis/${page.slug}`, qs.stringify(page));
}
在
config
在顶部,您需要指定 Gitlab 使用的 URL。
CI_PROJECT_ID
将由 Gitlab-CI 本身作为环境变量提供。
WIKI_DEPLOY_TOKEN
,但是,不会。在步骤 4 中进行设置。
package.json
,添加一个命令来运行该脚本:
"scripts": {
// ...
"wiki:build": "node wiki/build.js",
"wiki:deploy": "node wiki/deploy.js"
}
注:此示例将删除过时的页面,并根据在构建文件夹中找到的文件和 Wiki 已包含的文件更新或创建新页面。如果你也想有附件(图片),你需要使用
this API还。
WIKI_DEPLOY_TOKEN
为此,您需要点击右上角的头像 >
设置 .然后在左侧菜单中,
访问 token ,并使用
创建一个 token 接口(interface) 范围。名字无关紧要。现在复制此 token ,因为它只会显示一次。
WIKI_DEPLOY_TOKEN
的变量, 使它成为
蒙面这样它就不会出现在任何日志中,并且
保存变量 :
.gitlab-ci.yml
项目根目录下的文件。声明
generate_wiki
阶段:
stages:
# - tests
# - deploy
# ...
- generate_wiki
generate_wiki:
image: node:10
stage: generate_wiki
script:
- npm install
- npm run wiki:build # build the wiki in a directory
- npm run wiki:deploy # update it in Gitlab
only:
- master # Only when merging or pushing to master branch
# ... rest of your pipeline ...
如您所见,我们使用命令
wiki:build
和
wiki:deploy
在步骤 2 和 3 中声明。
/
├───src
│ └── index.js
├───wiki
│ ├── templates
│ │ └── home.mst
│ ├── build.js
│ └── deploy.js
├── .gitlab-ci.yml
└── package.json
第 6 步 - 插入掌握,享受魔法
关于gitlab wiki页面中的Javascript/html?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59203694/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!