请观察以下代码:
import Taro, { Component } from '@tarojs/taro'import { View } from '@tarojs/components'class Home extends Component {render () {return (<View>Hello World!</View>)}}
必须声明 Taro 和组件
在这段代码中,大写开头的 JSX 标签 View 表示它是一个 Taro 组件,尽管在整段代码中,变量 View 看起来并没有被调用,但也必须从 @tarojs/components 中引入声明。变量 Taro 也是一个必须引入声明的变量,因为我们在编译期和运行时会依赖这个变量做一些特殊处理。当你引入了组件时,一定要使用,不要出现没有使用的变量。
当你只用支持微信小程序时,可以不用引入组件例如
View这样的声明。但我们仍然强烈推荐你在顶部引入你将要使用的组件,这样编辑器/IDE 能更好地提前发现可能出现的问题,也为将来可能需要的多端转换留有余地。
首字母大写与驼峰式命名
在 Taro 中,所有组件都应当首字母大写并且使用大驼峰式命名法(Camel-Case)。
例如,下面的代码将无法按预期运行:
import Taro, { Component } from '@tarojs/taro'// 引入一个自定义组件组件import home_page from './page'// 错误!组件名应该首字母大写:class App extends Component {render () {return (<home_page message="Hello World!" />)}}
为了解决这个问题,我们将 home_page 重命名为 HomePage,然后使用 <HomePage /> 引用:
import Taro, { Component } from '@tarojs/taro'// 引入一个自定义组件组件import HomePage from './page'class App extends Component {render () {return (<HomePage message="Hello World!" />)}}
和 React/Nerv 不一样的地方在于,Taro 不支持使用
点表示法和运行时指定类型来引用组件,例如<MyComponents.DatePicker />这样的写法在 Taro 中是无法正确编译的。
