當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Serializer.deserialize方法代碼示例

本文整理匯總了TypeScript中angular2/src/web-workers/shared/serializer.Serializer.deserialize方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Serializer.deserialize方法的具體用法?TypeScript Serializer.deserialize怎麽用?TypeScript Serializer.deserialize使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在angular2/src/web-workers/shared/serializer.Serializer的用法示例。


在下文中一共展示了Serializer.deserialize方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: _handleCompilerMessage

 // TODO: Transfer the types with the serialized data so this can be automated?
 private _handleCompilerMessage(data: ReceivedMessage) {
   var promise: Promise<any>;
   switch (data.method) {
     case "compileHost":
       var directiveMetadata = this._serializer.deserialize(data.args[0], DirectiveMetadata);
       promise = this._renderCompiler.compileHost(directiveMetadata);
       this._wrapWebWorkerPromise(data.id, promise, ProtoViewDto);
       break;
     case "compile":
       var view = this._serializer.deserialize(data.args[0], ViewDefinition);
       promise = this._renderCompiler.compile(view);
       this._wrapWebWorkerPromise(data.id, promise, ProtoViewDto);
       break;
     case "mergeProtoViewsRecursively":
       var views = this._serializer.deserialize(data.args[0], RenderProtoViewRef);
       promise = this._renderCompiler.mergeProtoViewsRecursively(views);
       this._wrapWebWorkerPromise(data.id, promise, RenderProtoViewMergeMapping);
       break;
     default:
       throw new BaseException("not implemented");
   }
 }
開發者ID:goderbauer,項目名稱:angular,代碼行數:23,代碼來源:impl.ts

示例2: _createViewHelper

 private _createViewHelper(args: List<any>, method) {
   var hostProtoView = this._serializer.deserialize(args[0], RenderProtoViewRef);
   var fragmentCount = args[1];
   var startIndex, renderViewWithFragments;
   if (method == "createView") {
     startIndex = args[2];
     renderViewWithFragments = this._renderer.createView(hostProtoView, fragmentCount);
   } else {
     var selector = args[2];
     startIndex = args[3];
     renderViewWithFragments =
         this._renderer.createRootHostView(hostProtoView, fragmentCount, selector);
   }
   this._renderViewWithFragmentsStore.store(renderViewWithFragments, startIndex);
 }
開發者ID:goderbauer,項目名稱:angular,代碼行數:15,代碼來源:impl.ts

示例3: _handleRendererMessage

 private _handleRendererMessage(data: ReceivedMessage) {
   var args = data.args;
   switch (data.method) {
     case "createRootHostView":
     case "createView":
       this._createViewHelper(args, data.method);
       break;
     case "destroyView":
       var viewRef = this._serializer.deserialize(args[0], RenderViewRef);
       this._renderer.destroyView(viewRef);
       break;
     case "attachFragmentAfterFragment":
       var previousFragment = this._serializer.deserialize(args[0], RenderFragmentRef);
       var fragment = this._serializer.deserialize(args[1], RenderFragmentRef);
       this._renderer.attachFragmentAfterFragment(previousFragment, fragment);
       break;
     case "attachFragmentAfterElement":
       var element = this._serializer.deserialize(args[0], WebWorkerElementRef);
       var fragment = this._serializer.deserialize(args[1], RenderFragmentRef);
       this._renderer.attachFragmentAfterElement(element, fragment);
       break;
     case "detachFragment":
       var fragment = this._serializer.deserialize(args[0], RenderFragmentRef);
       this._renderer.detachFragment(fragment);
       break;
     case "hydrateView":
       var viewRef = this._serializer.deserialize(args[0], RenderViewRef);
       this._renderer.hydrateView(viewRef);
       break;
     case "dehydrateView":
       var viewRef = this._serializer.deserialize(args[0], RenderViewRef);
       this._renderer.dehydrateView(viewRef);
       break;
     case "setText":
       var viewRef = this._serializer.deserialize(args[0], RenderViewRef);
       var textNodeIndex = args[1];
       var text = args[2];
       this._renderer.setText(viewRef, textNodeIndex, text);
       break;
     case "setElementProperty":
       var elementRef = this._serializer.deserialize(args[0], WebWorkerElementRef);
       var propName = args[1];
       var propValue = args[2];
       this._renderer.setElementProperty(elementRef, propName, propValue);
       break;
     case "setElementAttribute":
       var elementRef = this._serializer.deserialize(args[0], WebWorkerElementRef);
       var attributeName = args[1];
       var attributeValue = args[2];
       this._renderer.setElementAttribute(elementRef, attributeName, attributeValue);
       break;
     case "setElementClass":
       var elementRef = this._serializer.deserialize(args[0], WebWorkerElementRef);
       var className = args[1];
       var isAdd = args[2];
       this._renderer.setElementClass(elementRef, className, isAdd);
       break;
     case "setElementStyle":
       var elementRef = this._serializer.deserialize(args[0], WebWorkerElementRef);
       var styleName = args[1];
       var styleValue = args[2];
       this._renderer.setElementStyle(elementRef, styleName, styleValue);
       break;
     case "invokeElementMethod":
       var elementRef = this._serializer.deserialize(args[0], WebWorkerElementRef);
       var methodName = args[1];
       var methodArgs = args[2];
       this._renderer.invokeElementMethod(elementRef, methodName, methodArgs);
       break;
     case "setEventDispatcher":
       var viewRef = this._serializer.deserialize(args[0], RenderViewRef);
       var dispatcher = new EventDispatcher(viewRef, this._bus.sink, this._serializer);
       this._renderer.setEventDispatcher(viewRef, dispatcher);
       break;
     default:
       throw new BaseException("Not Implemented");
   }
 }
開發者ID:goderbauer,項目名稱:angular,代碼行數:78,代碼來源:impl.ts


注:本文中的angular2/src/web-workers/shared/serializer.Serializer.deserialize方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。