生成js代码

V语言的开发重点在编译器前端,目前主要的编译器后端有4个:C/native/js/go。

js作为事实上的web前端汇编语言,已经有各种语言支持编译生成js代码,而且生成的js代码质量都不错,比如typescript,rescript等。

总感觉V还是集中精力定位在服务端,定位为"better C"就已经很好了,web前端不太可能采用V来生成js。

生成js代码

使用-o参数就可以

把当前目录的main.v代码生成main.js代码

最简单的V代码:

module main

fn main() {
	println('from main')
}

编译生成js代码:

v -o main.js ./main.v 

生成的js代码可以通过node运行

node ./main.js

基本类型对应

V的每一个基本类型都对应一个js同名函数

// builtin type casts
const [i8, i16, int, i64, u8, u16, u32, u64, f32, f64, int_literal, float_literal, size_t, bool, string, map, array] = [
	function(val) { return new builtin.i8(val) },
	function(val) { return new builtin.i16(val) },
	function(val) { return new builtin.int(val) },
	function(val) { return new builtin.i64(val) },
	function(val) { return new builtin.u8(val) },
	function(val) { return new builtin.u16(val) },
	function(val) { return new builtin.u32(val) },
	function(val) { return new builtin.u64(val) },
	function(val) { return new builtin.f32(val) },
	function(val) { return new builtin.f64(val) },
	function(val) { return new builtin.int_literal(val) },
	function(val) { return new builtin.float_literal(val) },
	function(val) { return new builtin.size_t(val) },
	function(val) { return new builtin.bool(val) },
	function(val) { return new builtin.string(val) },
	function(val) { return new builtin.map(val) },
	function(val) { return new builtin.array(val) }
]

代码对照表

常量

枚举

模块

函数

数组

字符串

字典

结构体

结构体方法

结构体访问控制

流程控制语句

类型定义

接口

泛型

错误处理

联合类型

运算符重载

条件编译

最后更新于