Heim > Web-Frontend > uni-app > Hauptteil

Worauf sollten wir bei der Anpassung von Uniapp an das WeChat-Applet achten?

青灯夜游
Freigeben: 2021-08-30 19:15:24
nach vorne
3717 Leute haben es durchsucht

Was sollten Sie bei der Anpassung von uniapp an das WeChat-Miniprogramm beachten? Der folgende Artikel wird Ihnen einige Vorsichtsmaßnahmen bei der Anpassung von Uniapp an das WeChat-Applet mitteilen. Ich hoffe, er wird Ihnen hilfreich sein!

Worauf sollten wir bei der Anpassung von Uniapp an das WeChat-Applet achten?

Dies ist auch mein erstes Mal, dass ich Uniapp spiele. Auf der offiziellen Website heißt es, dass es einmal codiert und auf mehreren Terminals veröffentlicht werden kann. Ehrlich gesagt war ich zunächst skeptisch. Mittlerweile ist die App jedoch entwickelt und die h5-Seite fast fertig. Jetzt müssen wir ein kleines Programm erstellen, was mich schon beim Gedanken daran sehr aufgeregt macht. .

Ich habe das Miniprogramm auf hbuilderx ausgeführt und die bekannte Anmeldeoberfläche mit Kapseln gesehen. Ich war sehr aufgeregt und habe mich angemeldet, um einen Blick darauf zu werfen. Infolgedessen waren alle Schaltflächen auf der Startseite verschwunden, und auch die Tableiste unten war verschwunden. . Dies ist nur der erste Schritt, und er hat mein Selbstvertrauen bereits schwer beschädigt. Ich hatte das Gefühl, zum ersten Mal beim Essen einer Krabbe erwischt zu werden! Glücklicherweise ist uniapp ziemlich zuverlässig. Schließlich habe ich die CommunityInformationen durchgesehen und diese Probleme endlich gelöst. Später stieß ich auf andere Probleme, also habe ich sie zusammengefasst und meine Erfahrungen geteilt. Einmal entwickeln und auf mehreren Terminals veröffentlichen, es wird seinem Ruf wirklich gerecht!

1. V-if vermeidet Fallstricke

Ein Blick in die offizielle Uniapp-Dokumentation zeigt, dass v-if Multi-End-Unterstützung unterstützt. Das Miniprogramm unterstützt nur WeChat-Miniprogramme. Nach dem Ausführen des Miniprogramms mit hbuilderx wird es zur WeChat-Befehlssyntax wx:if. Hier gibt es eine Grube, seien Sie also vorsichtig!

v-if-Anweisungsausdruck

Wenn der Anweisungsausdruck ein JSON-Objekt ist und der Attributwert Ihres -Objekts null enthält, sollten Sie darauf achten Im Allgemeinen ist es wie folgt:

rrree

Es ​​tritt ein Problem auf, wenn Ihr Code im Applet ausgeführt wird. Die Ansichtskomponente wird jedoch nicht gerendert. Sie kann in der App und in h5 normal angezeigt werden. Der Grund wurde bisher nicht gefunden. Es gibt ein Sprichwort, dass es mit einem Fehler in js in der Antike zusammenhängt (typeof(null) == „object“). Der neueste Kernel des WeChat-Miniprogramms basiert auf ihrem selbst entwickelten MWEB-Kernel, der ebenfalls auf einer Chrom-Modifikation basieren sollte. Ich weiß nicht, warum die Reaktionen hier so unterschiedlich sind. ! Überrascht. .

Die richtige Schreibweise sollte so aussehen:

<view v-if="a.b"></view>

//a对象
{
"b": "ss",
"c": null
}
Nach dem Login kopieren

2. Der Zindex der Ansicht

Dies ist auch eine Falle, für die der Grund nicht gefunden wurde. Mein ursprünglicher Code ist so und die App und h5 sind normal, aber wenn das Applet ausgeführt wird, nein, keine Reaktion nach dem Klicken:

<view v-if="a.b!==null"></view>

//a对象
{
"b": "ss",
"c": null
}
Nach dem Login kopieren

Ich kann sehen, wie viele Ebenen angewendet wurden. Wie haben Sie es am Ende gelöst? Erhöhen Sie einfach den Zindex-Wert der innersten Ansicht etwas und fertig! Ich verstehe nicht ganz, was mit dem WeChat-Miniprogramm los ist. Wenn Sie auch darauf stoßen, geben Sie ihm einfach Zindex! Funktionsobjekt. Das macht keinen Spaß. Bei der Front-End-Entwicklung werden häufig komplexe Objekte übergeben, und es kommt auch sehr häufig vor, dass Eigenschaftswerte Funktionen sind. Mein Szenario besteht darin, Spalten an eine Tabellenkomponente zu übergeben, z. B. die Rückgabe von Bildern und Schaltflächen basierend auf ihren Werten sie konvertieren?

Die Lösung, die ich hier anbiete, besteht darin, diese Konvertierungsfunktionen in ein globales Mischobjekt einzufügen. Wenn sie global eingemischt werden, bedeutet dies, dass alle Komponenten diese Funktionen haben, wenn das Spaltenobjekt an die Tabellenkomponente übergeben wird " Objekt Geben Sie der Funktion einfach einen Namen. Okay, hier kommt die Frage: Wenn meine Tabellenkomponente das Spaltenobjekt analysiert, wie kann ich die entsprechende Funktion über den Funktionsnamen finden und sie dann aufrufen? Ursprünglich war es mit eval() einfach zu implementieren, aber das WeChat-Applet hat diese Funktion sogar deaktiviert! ! Okay, wir sind schon so weit gekommen. Es gibt tatsächlich Alternativen, schauen Sie sich einfach die Schritte an! 1. Globales Mix-in

Wenn Sie über andere nützliche Daten verfügen, können Sie diese natürlich auch in die berechneten Eigenschaften einmischen zur Vue-Komponente.

<view><view><view @click="todo"></view></view></view>
Nach dem Login kopieren

2. Übergeben Sie den Methodennamen

Schauen Sie sich dieses Beispiel an, hier kann der Vorlage nur der Funktionsname tmtemp gegeben werden.

module.exports = {
 computed: {
  
 },
 methods: {
  tmtemp(row) {
   if (row.tm && row.tm != null) {
    return `<span style="text-align:center;">${row.tm}</span>`
   } else {
    return &#39;-&#39;
   }
  }
 }
}
Nach dem Login kopieren

3. Bewertungsalternative

Es gibt eine Open-Source-Bewertungsfunktion, hier ist die

Adresse

. Laden Sie den Quellcode lokal herunter, wenn die Tabale-Komponente auf die

columns: [{
      title: "测站编码",
      // key: "stcd"
      format: {
       names: ["stcd"],
       template: &#39;<span style="word-break: break-all">#stcd#</span>&#39;
      }
     },
     {
      title: &#39;测站名称&#39;,
      key: &#39;stnm&#39;
     },
     {
      title: &#39;最后一次上报时间&#39;,
      // key: &#39;tm&#39;,
      format: {
       names: [&#39;tm&#39;],
       codeChange: true,
                      //传函数名
       template: &#39;tmtemp&#39; 
      }
     },
     {
      title: &#39;在线状态&#39;,
      // key: &#39;onlinestate&#39;,
      width: &#39;146&#39;,
      format: {
       names: [&#39;onlinestate&#39;],
       codeChange: true,
                      //传函数名
       template: &#39;onlinetemp&#39;
      }
     }
    ]
Nach dem Login kopieren
Tabelle verweist Komponente zum Parsen. Verwenden Sie es einfach so:
function(row,col){
    if (col.format.codeChange) {//rpneval.calCommonExp
            tempHTML = binding.eval(&#39;tem($0)&#39;,[row],{tem:this[col.format.template]});
    }
}
Nach dem Login kopieren

简单解释下,binding.eval函数有三个参数,第一个是模板,tem可以随意取名,指代函数名;第二个是传入的参数,放在数组里;第三个就是一个函数名匹配对象,this[col.format.template]就是前面传过来的函数名。

4、存储常量参数

如果在小程序的组件中,传过去的函数需要用到当前组件里的参数,这个就不太好传了,因为table组件里只会传入row(列表行数据对象)、col(列名)这种参数,所以如果要用到组件内的其他参数传到table组件,一般要提到全局,可以给到状态管理,也可以给全局属性,看需要了。

四、小程序分包、上传

小程序为了良好性能的用户体验,对小程序的上传发布有要求。对于微信小程序,上传时,项目代码总大小不能超过16M,小程序还有一个分包的概念,要求各个分包大小不能超过2M。这里可以参考官方文档进行分包,细节我就不复述了。项目分完了包之后,pages.json中的配置应该是像这样,我直接从官方文档拷贝了一个例子:

{
  "pages":[
    "pages/index",
    "pages/logs"
  ],
  "subpackages": [
    {
      "root": "packageA",
      "pages": [
        "pages/cat",
        "pages/dog"
      ]
    }, {
      "root": "packageB",
      "name": "pack2",
      "pages": [
        "pages/apple",
        "pages/banana"
      ]
    }
  ]
}
Nach dem Login kopieren

packageA与packageB就是分包,主包是除了subPackages里的内容,其他所有的内容都是主包,pages只是部分内容 ,包括第三方库、样式及静态文件默认情况下都是会在主包里。一般建议主包的pages中就只留tabbar对应的页面,其他的放分包的中,像这样:

Worauf sollten wir bei der Anpassung von Uniapp an das WeChat-Applet achten?

光这些还不够,因为主包东西太多。还有什么要注意的地方呢?以下是要点:

1、使用hbuilderx自带压缩

Worauf sollten wir bei der Anpassung von Uniapp an das WeChat-Applet achten?

如图,运行到小程序时将“运行时是否压缩代码”勾选就可以了,这样基本可以压缩掉一大半占用空间。

2、将局部引用文件分到对应分包

代码压缩了,但是主包还是很大怎么办,给主包分点东西出来!举个例子,在components文件夹下都是引用的三方组件,可以把这些组件分到各个分包里。这里要注意下分包原则,后面都以此为准,官方文档也有说明,我这里总结下:

  • 公共组件或者公共资源,就是各个包都会用到的,要放在类似components这样的公共文件里不能动
  • 分包中单独用到的组件,可以放在各自的分包里
  • 主包可以引用分包中的文件,分包无法引用其他分包的东西,只能引用自己包里和主包里的东西

3、static文件夹内只放静态文件

这里有个要注意的地方:uni-app的编译器会编译40k以下的文件为base64方式。uni-app编译器是不会编译static里面的内容的,所以,这里面只能放静态文件,像图片这种可以放里面;其他的像样式文件,字体这种就不行了,你得从static中移出来,就放在分包里,主包也可以调用得到。

Worauf sollten wir bei der Anpassung von Uniapp an das WeChat-Applet achten?

像这样,看着是有点别扭,但是没办法,为了小程序,为了能跨多端,只能牺牲长相了。其实我一开始并没有想到要分包,后面有经验了就可以在项目设计时就想好分包,这样各个分包有专门的作用,不至于看着别扭了。

4、压缩vendor.js文件

vendor.js这个是小程序里面所有第三方库的压缩包,这个一般不小,要压缩这个,官方有说明方法,这里提一下,在package.json里加上这段,注意得是cli创建的项目才会有用。

  "dev:mp-weixin": "cross-env NODE_ENV=development UNI_PLATFORM=mp-weixin vue-cli-service uni-build --watch --minimize"
Nach dem Login kopieren

好了,关于uniapp项目运行到微信小程序,要注意的地方就总结这么多,希望对你有用!不得不承认,学会用uniapp还是挺省事的,值得学习!

推荐:《uniapp教程

Das obige ist der detaillierte Inhalt vonWorauf sollten wir bei der Anpassung von Uniapp an das WeChat-Applet achten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:juejin.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage