Front-end Frameworks in Weex

Vue and Rax

Front-end technologies seem flourishing and productive. Using front-end frameworks in production is a good way to write maintainable apps.

However, Weex is not a front-end framework. Indeed, front-end frameworks are just the syntax layer or DSL (Domain-specific Language) of Weex, they are decoupled from native render engines. In another word, Weex does not rely on any specific front-end frameworks. With the evolution of the technology, Weex can integrate more widely used front-end frameworks as well.

Currently, Weex mainly supports Vue.js and Rax, and those frameworks are already integrated into Weex SDK, you don't need to require them manually.

Learn some basics of Vue.js or Rax could be very helpful when you are using Weex.

It is better to learn some basics of Vue.js or Rax before using Weex.

Framework Type Annotation

Weex only determined which front-end framework is used of a specific page at runtime (just before rendering the page). So you have to mark what type of front-end framework you are using in the js bundle.

Using Comment

In v0.16 and earlier, Weex is using specific format comments to annotate the framework type, the format is // { "framework": "Xxx" }, the Xxx in it is the name of front-end framework.

NOTICE: The comment type annotation must be placed at the beginning of the code. Only spaces or blank lines can be put before it.

For example, the comment type annotation of Vue is:

// { "framework": "Vue" }

The comment type annotation of Rax is:

// { "framework": "Rax" }

Using Directive Prologue

Using comments is not a robust way to declare the framework type, because it may be removed during compiling or packaging. Since the v0.17, Weex supports using Directive Prologue to indicate the framework type. The format of directive prologue type annotation is "use weex:xxx";, the Xxx in it is the name of front-end framework. Both ' (single quote) and " (double quotes) are fine, but must be lower case.

NOTICE: The directive prologue type annotation must be placed before all runnable codes. Only spaces, blank lines or comments can be put before it.

For example, the directive prologue type annotation of Vue is:

"use weex:vue";

The directive prologue type annotation of Rax is:

"use weex:rax";

Be Compatible with All Versions of Weex

If you are using v0.17 or higher version of Weex SDK, recommend you to use "use weex:xxx"; as the type annotation. But if consider to be compatible with all versions of Weex, you can use both comments and directive prologue.

For example, the compatible type annotation of Vue is:

// { "framework": "Vue" }
"use weex:vue";

The compatible type annotation of Rax is:

// { "framework": "Rax" }
"use weex:rax";

Vue.js

Weex integrated the v2 version of Vue.js since WeexSDK v0.10.0 is released at 2017/02/17. Vue (pronounced /vjuː/, like view) is a progressive front-end framework for building user interfaces. Please refer to its official website for more information.

::: tip Please refer to Use Vue.js in Weex document to learn more technics about Weex and Vue. :::

Rax

Rax is a front-end framework with React-compatible APIs.

Please refer to Rax's official website to get more information.