stml页面

2020-12-29 10:53 更新

stml介绍 stml(single template markup language)文件是一个专用的文件类型,其结构和Vue的单文件组件 (SFC)相似,用类Html语法描述一个组件/页面。

一个stml文件一般包含三种类型的顶级语言块<template>,<script>和<style>,同时支持引入外部js或者css文件,以及其他stml组件。

stml文件最终被分别编译为APP、小程序代码。

App端加载stml页面的方式

在config.xml中全局配置avm字段。配置后打开页面默认使用原生渲染引擎,当打开标准H5页面时,需将openWin、openFrame等方法的avm参数设置为false。

  1. <preference name="avm" value="true"/>

使用openWin、openFrame等方法打开页面时设置avm参数。

  1. api.openWin({
  2. name: 'test',
  3. url: '../pages/test.stml',
  4. avm: true
  5. });

代码示例

一个典型的.stml文件代码如下:

  1. <template>
  2. <view>
  3. <view class="header">
  4. <text>{this.data.title}</text>
  5. </view>
  6. <view class="content">
  7. <text>{this.data.content}</text>
  8. </view>
  9. <view class="footer">
  10. <text>{this.data.footer}</text>
  11. </view>
  12. </view>
  13. </template>
  14. <style>
  15. .header {
  16. height: 45px;
  17. }
  18. .content {
  19. flex-direction:row;
  20. }
  21. .footer {
  22. height: 55px;
  23. }
  24. </style>
  25. <script>
  26. export default {
  27. name: 'api-test',
  28. apiready(){
  29. console.log("Hello APICloud");
  30. },
  31. data(){
  32. return {
  33. title: 'Hello App',
  34. content: 'this is content',
  35. footer: 'this is footer'
  36. }
  37. }
  38. }
  39. </script>

代码块描述 <template>:stml文件允许最多包含一个template块,且template下仅允许包含一个子节点。template块类似于标准HTML中的body标签。

<script>:stml文件允许最多包含一个script块,script块类似于标准Html的script标签。该块内可使用import方式引入外部js,被引入的js内容将被编译到最终的js组件中。例如:

  1. <script>
  2. import './path/utils.js';
  3. export default {
  4. name: 'api-test',
  5. }
  6. </script>

<style>:stml文件允许包含一个或多个style块,style块类似于标准Html的style标签。该块支持以src的方式引入外部css,被引入的css内容将被编译到最终的js组件中。例如:

  1. <style src='./path/common.css' />
  2. <style>
  3. .header{
  4. height: 45px;
  5. }
  6. </style>

编译器会解析stml文件,提取每个语言块,分别编译导出为APP(JS组件 / 页面)、H5(SPA)、小程序(WXML / WXSS / JS)代码,用于不同终端的渲染。

编译后的App js代码参考:

  1. class ApiTest extends Component {
  2. data = {
  3. title: 'Hello App',
  4. content: 'this is content',
  5. footer: 'this is footer'
  6. }
  7. apiready () {
  8. console.log("Hello APICloud");
  9. }
  10. render() {
  11. return (
  12. <view>
  13. <view class='header'>
  14. <text>{this.data.title}</text>
  15. </view>
  16. <view class='content'>
  17. <text>{this.data.content}</text>
  18. </view>
  19. <view class='footer'>
  20. <text>{this.data.footer}</text>
  21. </view>
  22. </view>
  23. );
  24. }
  25. }
  26. ApiTest.css = {
  27. '.header': {
  28. height: '45px'
  29. },
  30. '.content': {
  31. flex: 1
  32. },
  33. '.footer': {
  34. height: '55px'
  35. }
  36. }
  37. avm.define('api-test', ApiTest);
  38. avm.render(<api-test />, 'body');

该代码为编译中间过程的临时代码,是ES6规范的代码,符合avm.js单语言片段模式要求。在输出之前,还会经过一系列的处理,最终被编译为ES5规范的代码,用于DeepEngine或者标准浏览器执行。

avm.define avm.define函数用于声明或者定义一个组件。接收两个参数,组件名(例如"a-button")和组件对象。

avm.render avm.render函数用于声明将已定义的组件渲染到某元素上。默认渲染到body,body为窗口或者页面的根元素。

以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号