Chrome 브라우저에서 WeChat 애플릿 실행 및 WebStorm 사용 정보

不言
풀어 주다: 2018-06-27 09:40:08
원래의
2991명이 탐색했습니다.

이 글에서는 주로 Chrome 브라우저에서 WeChat 애플릿 실행 및 WebStorm 사용에 대한 관련 정보를 소개합니다. 필요한 친구가 참고할 수 있습니다.

"WeChat 애플릿"의 개발 프레임워크는 경험하기에 나쁘지 않습니다. UI와 함께 제공됩니다. 뼈대. 그러나 문제는 그의 IDE 성능이 매우 좋지 않다는 것입니다. 사실 그것은 주로 제가 수년 동안 WebStorm 라이센스를 구입했기 때문입니다. 그러므로 나는 그의 IDE가 내 유료 IDE만큼 유용하지 않다고 생각합니다.

그리고 자유와 오픈 소스를 지지하는 "GitHub China의 수석 마크다운 프로그래머"로서. 위챗의 '위챗 미니 프로그램'은 웹을 열고 닫는 데 앞장서고 있으며, 우리는 더 이상 코드를 즐겁게 공유할 수 없습니다.

내버려두면 미래의 웹 세상이 불안해질 것입니다.

알겠습니다. 말도 안 되는 소리는 그만 하세요.

글이 너무 길어서 읽고 싶지 않으시면 데모만 보시면 됩니다. 하하:

GitHub: https://github.com/phodal/weapp-webdemo
미리보기: http://weapp.phodal.com/

실제 MINA의 세 가지 기본 요소

"WeChat Mini 프로그램" 뒤에는 MINA라는 프레임워크가 있습니다. 이전 기사에서는 거의 소개했습니다. 이제 파이프라인을 소개하겠습니다.

Transform wxml and wxss

WXML 및 WXSS를 수정할 때 브라우저에 미치는 영향을 보려면 프로젝트를 다시 컴파일해야 합니다. 이때 일부 변환 작업이 백그라운드에서 수행됩니다.

1.wcc는 wxml을 genrateFun으로 변환합니다. 이 메서드를 실행하면 가상 DOM이 생성됩니다.
2.wxss는 wxss를 CSS로 변환합니다. 이는 논의 대상입니다.

wcc 및 wxss는 공급업체 디렉토리에서 얻을 수 있습니다. "WeChat 웹 개발자 도구"에 help를 입력하면 다음을 얻을 수 있습니다.

openVendor()를 실행하면 wcss, wxss 위의 4개 파일을 얻을 수 있습니다. , WAService.js, WAWebview.js.

js 파일 변환

js 파일의 경우 app.js 파일은 다음과 같습니다.

App({
onLaunch: function () { }
})
로그인 후 복사

변환 후

define("app.js", function(require, module){var window={Math:Math}/*兼容babel*/,location,document,navigator,self,localStorage,history,Caches;
  App({
   onLaunch: function () {

   }
  })
});
require("app.js");
로그인 후 복사
가 됩니다. 이게 뭔지 이미 아시겠지만 설명하고 싶지도 않고 설명할 수도 없어요~~. 동일:

define("pages/index/index.js", function(require, module){var window={Math:Math}/*兼容babel*/,location,document,navigator,self,localStorage,history,Caches;
  Page({
   data: {
    text: initData
   }
  });
 require("pages/index/index.js");
로그인 후 복사

html에서 어떻게 대체되거나 추가되는지에 대해서는 설명하지 않겠습니다.

미나는 어떻게 작동하나요?

페이지를 실행하려면 가상 돔, 즉 다음과 같이 wcc로 변환된 함수가 필요합니다.

/*v0.7cc_20160919*/
  var $gwxc
  var $gaic={}
  $gwx=function(path,global){
   function _(a,b){b&&a.children.push(b);}
   function _n(tag){$gwxc++;if($gwxc>=16000){throw 'enough, dom limit exceeded, you don\'t do stupid things, do you?'};return {tag:tag.substr(0,3)=='wx-'?tag:'wx-'+tag,attr:{},children:[]}}
   function _s(scope,env,key){return typeof(scope[key])!='undefined'?scope[key]:env[key]}
   function _wl(tname){console.warn('template `' + tname + '` is being call recursively, will be stop.')}
   function _ai(i,p,e,me){var x=_grp(p,e,me);if(x)i.push(x);else{console.warn('path `'+p+'` not found from `'+me+'`')}}
   function _grp(p,e,me){if(p[0]!=&#39;/&#39;){var mepart=me.split(&#39;/&#39;);mepart.pop();var ppart=p.split(&#39;/&#39;);for(var i=0;i<ppart.length;i++){if( ppart[i]==&#39;..&#39;)mepart.pop();else if(!ppart[i])continue;else mepart.push(ppart[i]);}p=mepart.join(&#39;/&#39;);}if(me[0]==&#39;.&#39;&&p[0]==&#39;/&#39;)p=&#39;.&#39;+p;if(e[p])return p;if(e[p+&#39;.wxml&#39;])return p+&#39;.wxml&#39;;}
//以下省略好多字。
로그인 후 복사

그런 다음

document.dispatchEvent(new CustomEvent("generateFuncReady", {
  detail: {
   generateFunc: $gwx(&#39;index.wxml&#39;)
  }
 }))
로그인 후 복사
와 같은 스크립트를 HTML에 추가합니다.

이런 사건이 일어나게 됩니다. 간단히 WXWebview.js를 분할하여 여러 기능 구성 요소를 얻었습니다.

define.js, 여기에서 AMD 모듈화가 정의되었습니다.
  1. exparser.js, WXML 태그를 HTML 태그로 변환하는 데 사용됨
  2. exparser-behvaior .js는 다양한 태그의 일부 동작을 정의합니다.
  3. mobile.js는 이벤트 라이브러리여야 하지만 상관하지 않는 것 같습니다.
  4. page.js, 페이지와 앱이 정의된 핵심 코드입니다.
  5. report.js, 귀하가 말하는 모든 내용은 법정에서 증거로 사용될 수 있습니다.
  6. virtual_dom.js, wcc와 함께 사용되는 가상 돔 구현으로, 그 안에 component.css가 있거나 weui
  7. wa-wx.js라고 불릴 수 있습니다. 여기서 다양한 WeChat API, WebView 및 네이티브가 정의되어 있으며 이는 아래 WX와 충돌합니다.
  8. wx.js, 위와 동일하지만 약간 다릅니다.
  9. wxJSBridge.js, Weixin JS Bridge

  10. 그래서 위의 컴포넌트를 사용하여 다양한 위치를 정의했습니다. 사용자 정의 generateFuncReady 이벤트를 트리거하면 virtual_dom.js가 Render를 인수합니다.

document.addEventListener("generateFuncReady", function (e) {
 var generateFunc = e.detail.generateFunc;
 wx.onAppDataChange && generateFunc && wx.onAppDataChange(function (e) {
  var i = generateFunc((0, d.getData)());
  if (i.tag = "body", e.options && e.options.firstRender){
   e.ext && ("undefined" != typeof e.ext.webviewId && (window.__webviewId__ = e.ext.webviewId), "undefined" != typeof e.ext.downloadDomain && (window.__downloadDomain__ = e.ext.downloadDomain)), v = f(i, !0), b = v.render(), b.replaceDocumentElement(document.body), setTimeout(function () {
    wx.publishPageEvent(p, {}), r("firstRenderTime", n, Date.now()), wx.initReady && wx.initReady()
   }, 0);
  } else {
   var o = f(i, !1), a = v.diff(o);
   a.apply(b), v = o, document.dispatchEvent(new CustomEvent("pageReRender", {}));
  }
 })
})
로그인 후 복사

따라서 여기에서 얻은 Dom 결과는 다음과 같습니다.

<wx-view class="btn-area">
 <wx-view class="body-view">
  <wx-text><span style="display:none;"></span><span></span></wx-text>
  <wx-button>add line</wx-button>
  <wx-button>remove line</wx-button>
 </wx-view>
</wx-view>
로그인 후 복사

그리고 우리가 작성한 wxml은 다음과 같습니다.

<view class="btn-area">
 <view class="body-view">
 <text>{{text}}</text>
 <button bindtap="add">add line</button>
 <button bindtap="remove">remove line</button>
 </view>
</view>
로그인 후 복사

분명히 view는 wx-view로 변환되고, 텍스트는 wx-text로 변환됩니다. 이 변환은 가상 dom.js에서 호출되며 호출되는 메서드는 exparser입니다.

안타깝게도 데이터 초기화가 막히네요~~. 이벤트 시스템이 두가지가 있어서 좀 헷갈리네요. 그 중 하나는 WeixinJSBridge이고, 다른 하나는 앱 엔진의 이벤트 시스템입니다. 이 둘은 서로 얽힐 수 없는 것 같습니다. . .

WebStorm을 사용하여 개발

브라우저에서 실행하기 전에 다음과 같은 일부 메서드를 간단히 모의 처리해야 합니다. .postMessage

WeixinJSCore.publishHandler
  1. WeixinJSCore..invokeHandler
  2. 그런 다음 config.json의 일부 내용을 __wxConfig로 변경합니다. 예:
  3. __wxConfig = {
     "debug": true,
     "pages": ["index"],
     "window": {
      "backgroundTextStyle": "light",
      "navigationBarBackgroundColor": "#fff",
      "navigationBarTitleText": "WeChat",
      "navigationBarTextStyle": "black"
     },
     "projectConfig": {
    
     },
     "appserviceConfig": {
    
     },
     "appname": "fdfafafafafafafa",
     "appid": "touristappid",
     "apphash": 2107567080,
     "isTourist": true,
     "userInfo": {}
    }
    로그인 후 복사

  4. 예를 들어 여기 앱 이름은 하하하하하하하하하입니다. - 제 집은 푸젠성이에요.

    그런 다음 각 js 파일을 HTML에 삽입하세요.
  5. 我们还需要一个自动化的glup脚本来watch wxml和wxss的修改,然后编译,如:

    exec(&#39;./vendor/wcc -d &#39; + inputPath + &#39; > &#39; + outputFileName, function(err, stdout, stderr) {
       console.log(stdout);
       console.log(stderr);
    });
    로그인 후 복사

    以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

    相关推荐:

    微信小程序页面跳转功能中从列表的item项跳转到下一个页面的实现方法

    微信小程序中定义全局数据和函数复用及模版的介绍

    微信小程序中显示html格式内容的方法

    위 내용은 Chrome 브라우저에서 WeChat 애플릿 실행 및 WebStorm 사용 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!