codecamp

单语言片段模式定义组件

单语言片段模式定义组件为avm.js支持的两种编程模式之一,使用纯js即可完成组件的定义,或者页面的开发,开发风格类似于React。

使用JS定义一个组件 / 页面

JS组件 / 页面符合Web Components 规范,使用define函数进行组件定义,使用render函数渲染到终端。

定义组件:

// api-test.js:


avm.define('api-test', class extends Component {
    render() {
        return (
            <view>
                <text>Hello APP</text>
            </view>
        );
    }
});

添加样式:

avm.define('api-test', class extends Component {

    
    css(){
        return `.header {
            height: 45
        }`
    }

    
    render() {
        return (
            <view class='header'>
                <text>Hello APP</text>
            </view>
        );
    }
});

引入外部样式:

import commoncss from './assets/common.css';


avm.define('api-test', class extends Component {

    
    css(){
        return commoncss;
    }

    
    render() {
        return (
            <view class='header'>
                <text>Hello APP</text>
            </view>
        );
    }
});

数据绑定:

avm.define('api-test', class extends Component {

    
    data = {
        title: 'Hello APP'
    }

    
    css(){
        return `.header {
            height: 45
        }`
    }

    
    render() {
        return (
            <view class='header'>
                <text>{this.data.title}</text>
            </view>
        );
    }
});

在其他页面使用组件:

// app-index.js:


import './components/api-test.js';


avm.define('app-index', class extends Component {

    
    data = {
        title: 'Hello APP',
        errorState: false
    }

    
    css(){
        return `#app {   
            text-align: center;  
            color: #2c3e50;  
            margin-top: 60px;  
        }`;
    }

    
    render() {
        return (
            <view id="app">  
                <img src="./assets/logo.png" />  
                <api-test></api-test>
            </view>
        );
    }
});


avm.render(<app-index />);
//avm.render(<app-index />, 'body');
//avm.render(<app-index />, $('body'));
单文件(SFC)模式定义组件
组件生命周期
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }