最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Taro(一)

    正文概述 掘金(yolkpie)   2021-03-12   536

    简介

    现如今市面上端的形态多种多样,Web、React-Native、微信小程序等各种端大行其道,当业务要求同时在不同的端都要求有所表现的时候,针对不同的端去编写多套代码的成本显然非常高,这时候只编写一套代码就能够适配到多端的能力就显得极为需要。 使用 Taro,我们可以只书写一套代码,再通过 Taro 的编译工具,将源代码分别编译出可以在不同端(微信/百度/支付宝/字节跳动/QQ 小程序、快应用、H5、React-Native 等)运行的代码。

    一、 Taro 的安装与使用

    1.1 安装

    $ npm install -g @tarojs/cli
    taro -V
    

    1.2 使用

    使用命令创建模板项目

    $ taro init myApp
    

    Taro(一)

    1.2.1 微信小程序

    选择微信小程序模式,需要自行下载并打开微信开发者工具,然后选择项目根目录进行预览

    微信小程序编译预览及打包

    # npm script
    $ npm run dev:weapp
    $ npm run build:weapp
    
    1.2.2 百度小程序

    选择百度小程序模式,需要自行下载并打开百度开发者工具,然后在项目编译完后选择项目根目录下 dist 目录进行预览

    百度小程序编译预览及打包

    # npm script
    $ npm run dev:swan
    $ npm run build:swan
    
    1.2.3 支付宝小程序

    选择支付宝小程序模式,需要自行下载并打开支付宝小程序开发者工具,然后在项目编译完后选择项目根目录下 dist 目录进行预览

    支付宝小程序编译预览及打包:

    # npm script
    $ npm run dev:alipay
    $ npm run build:alipay
    
    1.2.4 H5

    H5 编译预览及打包:

    # npm script
    $ npm run dev:h5
    
    # 仅限全局安装
    $ taro build --type h5 --watch
    
    1.2.5 React Native
    # npm script
    $ npm run dev:rn
    

    1.3 更新 Taro

    Taro 提供了更新命令来更新 CLI 工具自身和项目中 Taro 相关的依赖。

    更新 taro-cli 工具

    # taro
    $ taro update self
    # npm
    

    更新项目中 Taro 相关的依赖,这个需要在你的项目下执行

    $ taro update project
    

    二、Taro 开发说明与注意事项

    2.1 微信小程序开发工具的配置

        - 设置关闭 ES6 转 ES5 功能
        - 设置关闭上传代码时样式自动补全
        - 设置关闭代码压缩上传
    

    Taro(一)

    2.2 Taro 与 React 的差异

    由于微信小程序的限制,React 中某些写法和特性在 Taro 中还未能实现,后续将会逐渐完善。 截止到本小册发布前,Taro 的最新版本为 1.1,因此以下讲解默认版本为 1.1

    2.2.1 暂不支持在 render() 之外的方法定义 JSX

    由于微信小程序的 template 不能动态传值和传入函数,Taro 暂时也没办法支持在类方法中定义 JSX

    无效情况

    class App extends Component {
      _render() {
        return <View />
      }
    }
    
    class App extends Component {
      renderHeader(showHeader) {
        return showHeader && <Header />
      }
    }
    
    class App extends Component {
      renderHeader = (showHeader) => {
        return showHeader& & <Header />
      }
    }...
    

    解决方案

    在 render 方法中定义

    class App extends Component {
    
      render () {
        const { showHeader, showMain } = this.state
        const header = showHeader && <Header />
        const main = showMain && <Main />
        return (
          <View>
            {header}
            {main}
          </View>
        )
      }
    }...
    

    2.2.2 不能在包含 JSX 元素的 map 循环中使用 if 表达式

    无效情况

    numbers.map((number) => {
      let element = null
      const isOdd = number % 2
      if (isOdd) {
        element = <Custom />
      }
      return element
    })
    
    numbers.map((number) => {
      let isOdd = false
      if (number % 2) {
        isOdd = true
      }
      return isOdd && <Custom />
    })...
    

    解决方案 尽量在 map 循环中使用条件表达式或逻辑表达式。

    numbers.map((number) => {
      const isOdd = number % 2
      return isOdd ? <Custom /> : null
    })
    
    numbers.map((number) => {
      const isOdd = number % 2
      return isOdd && <Custom />
    })...
    

    2.2.3 不能使用 Array.map 之外的方法操作 JSX 数组

    Taro 在小程序端实际上把 JSX 转换成了字符串模板,而一个原生 JSX 表达式实际上是一个 React/Nerv 元素(react - element)的构造器,因此在原生 JSX 中你可以对任何一组 React 元素进行操作。但在 Taro 中你只能使用 map 方法,Taro 转换成小程序中 wx:for…

    无效情况

    test.push(<View />)
    
    numbers.forEach(numbers => {
      if (someCase) {
        a = <View />
      }
    })
    
    test.shift(<View />)
    
    components.find(component => {
      return component === <View />
    })
    
    components.some(component => component.constructor.__proto__ === <View />.constructor)
    
    numbers.filter(Boolean).map((number) => {
      const element = <View />
      return <View />
    })...
    
    

    解决方案

    先处理好需要遍历的数组,然后再用处理好的数组调用 map 方法。

    numbers.filter(isOdd).map((number) => <View />)
    
    for (let index = 0; index < array.length; index++) {
      // do you thing with array
    }
    
    const element = array.map(item => {
      return <View />
    })...
    

    2.2.4 不能在 JSX 参数中使用匿名函数

    无效情况

    <View onClick={() => this.handleClick()} />
    
    <View onClick={(e) => this.handleClick(e)} />
    
    <View onClick={() => ({})} />
    
    <View onClick={function () {}} />
    
    <View onClick={function (e) {this.handleClick(e)}} />...
    

    解决方案 使用 bind 或 类参数绑定函数。

    <View onClick={this.props.hanldeClick.bind(this)} />
    

    2.2.5 不能在 JSX 参数中使用对象展开符

    微信小程序组件要求每一个传入组件的参数都必须预先设定好,而对象展开符则是动态传入不固定数量的参数。所以 Taro 没有办法支持该功能
    

    无效情况

    <View {...this.props} />
    
    <View {...props} />
    
    <Custom {...props} />
    

    解决方案 开发者自行赋值:

    render () {
        const { id, title } = obj
        return <View id={id} title={title} />
    }...
    

    2.2.6 不允许在 JSX 参数(props)中传入 JSX 元素

    由于微信小程序内置的组件化的系统不能通过属性(props) 传函数,而 props 传递函数可以说是 React 体系的根基之一,我们只能自己实现一套组件化系统。而自制的组件化系统不能使用内置组件化的 slot 功能。两权相害取其轻,我们暂时只能不支持该功能…

    无效情况

    <Custom child={<View />} />
    
    <Custom child={() => <View />} />
    
    <Custom child={function () { <View /> }} />
    
    <Custom child={ary.map(a => <View />)} />...
    

    解决方案

    通过 props 传值在 JSX 模板中预先判定显示内容,或通过 props.children 来嵌套子组件

    2.2.7 不支持无状态组件(Stateless Component)

    由于微信的 template 能力有限,不支持动态传值和函数,Taro 暂时只支持一个文件自定义一个组件。为了避免开发者疑惑,暂时不支持定义 Stateless Component

    无效情况

    function Test () {
      return <View />
    }
    
    function Test (ary) {
      return ary.map(() => <View />)
    }
    
    const Test = () => {
      return <View />
    }
    
    const Test = function () {
      return <View />
    }...
    

    解决方案 使用 class 定义组件。

    class App extends Component {
      render() {
        return <View />;
      }
    }
    

    2.3 命名规范

    • 方法名不能含有数字
    • 方法名不能以下划线开头或结尾
    • 方法名的长度不能大于 20

    请遵守以上规则,否则编译后的代码在微信小程序中会报以下错误

    Taro(一)

    2.4 推荐安装 ESLint 编辑器插件

    Taro(一) Taro(一)

    2.5 最佳编码方式

    组件传递函数属性名以 on 开头

    在 Taro 中,父组件要往子组件传递函数,属性名必须以 on 开头

    // 调用 Custom 组件,传入 handleEvent 函数,属性名为 `onTrigger`
    class Parent extends Component {
    
      handleEvent () {
    
      }
    
      render () {
        return (
          <Custom onTrigger={this.handleEvent}></Custom>
        )
      }
    }...
    

    这是因为,微信小程序端组件化是不能直接传递函数类型给子组件的,在 Taro 中是借助组件的事件机制来实现这一特性,而小程序中传入事件的时候属性名写法为 bindmyevent 或者 bind:myevent

    <!-- 当自定义组件触发“myevent”事件时,调用“onMyEvent”方法 -->
    <component-tag-name bindmyevent="onMyEvent" />
    <!-- 或者可以写成 -->
    <component-tag-name bind:myevent="onMyEvent" />
    

    小程序端不要在组件中打印传入的函数

    小程序端不要将在模板中用到的数据设置为 undefined

    • 由于小程序不支持将 data 中任何一项的 value 设为 undefined ,在 setState 的时候也请避免这么用。你可以使用 null 来替代。
    • 小程序端不要在组件中打印 this.props.children 在微信小程序端是通过 来实现往自定义组件中传入元素的,而 Taro 利用 this.props.children 在编译时实现了这一功能, this.props.children 会直接被编译成 标签,所以它在小程序端属于语法糖的存在,请不要在组件中打印它…

    组件 state 与 props 里字段重名的问题

    小程序中页面生命周期 componentWillMount 不一致问题

    // 错误写法
    render () {
      // 在 willMount 之前无法拿到路由参数
      const abc = this.$router.params.abc
      return <Custom adc={abc} />
    }
    
    // 正确写法
    componentWillMount () {
      const abc = this.$router.params.abc
      this.setState({
        abc
      })
    }
    render () {
      // 增加一个兼容判断
      return this.state.abc && <Custom adc={abc} />
    }
    

    对于不需要等到页面 willMount 之后取路由参数的页面则没有任何影响…

    JS 编码必须用单引号

    process.env 的使用

    // 错误写法,不支持
    const { NODE_ENV = 'development' } = process.env
    if (NODE_ENV === 'development') {
      ...
    }
    
    // 正确写法
    if (process.env.NODE_ENV === 'development') {
    
    }...
    

    预加载

    Taro 提供了 componentWillPreload 钩子,它接收页面跳转的参数作为参数。可以把需要预加载的内容通过 return 返回,然后在页面触发 componentWillMount 后即可通过 this.$preloadData 获取到预加载的内容。…

    class Index extends Component {
      componentWillMount () {
        console.log('isFetching: ', this.isFetching)
        this.$preloadData
          .then(res => {
            console.log('res: ', res)
            this.isFetching = false
          })
      }
    
      componentWillPreload (params) {
        return this.fetchData(params.url)
      }
    
      fetchData () {
        this.isFetching = true
        ...
      }
    }...
    

    三、Taro 设计思想及架构

    Taro(一)

    3.1 抹平多端差异

    以小程序和 Web 端为例

    Taro(一)

    Taro(一)

    • 可以看出小程序和 Web 端上组件标准与 API 标准有很大差异,这些差异仅仅通过代码编译手段是无法抹平的,例如你不能直接在编译时将小程序的 直接编译成 ,因为他们虽然看上去有些类似,但是他们的组件属性有很大不同的,仅仅依靠代码编译,无法做到一致,同理,众多 API 也面临一样的情况。针对这样的情况,Taro 采用了定制一套运行时标准来抹平不同平台之间的差异

    起源地下载网 » Taro(一)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元