gpt4 book ai didi

angular - 扩展 Angular 4 通用渲染器

转载 作者:太空狗 更新时间:2023-10-29 17:00:13 26 4
gpt4 key购买 nike

我希望有人能帮助解决这个问题的逻辑。我想修改 angular universal 为每个组件注入(inject)样式的方式。有谁知道如何扩展渲染器并通过执行 api 请求从其他地方获取样式表。我只需要一个关于渲染器示例和 api 请求的示例,我想我可以自己弄清楚。

我正在看这个旧的。 https://github.com/ralfstx/angular2-renderer-example/blob/master/src/custom-renderer.ts

import {
Injectable,
Renderer,
RootRenderer,
RenderComponentType
} from '@angular/core';

export class Element {
constructor(private nodeName: string, private parent?: Element) {

}
toString() {
return '<' + this.nodeName + '>';
}
};

@Injectable()
export class CustomRootRenderer extends RootRenderer {
private _registeredComponents: Map<string, CustomRenderer> = new Map<string, CustomRenderer>();

renderComponent(componentProto: RenderComponentType): Renderer {
var renderer = this._registeredComponents.get(componentProto.id);
if (!renderer) {
renderer = new CustomRenderer(this);
this._registeredComponents.set(componentProto.id, renderer);
}
return renderer;
}
}

@Injectable()
export class CustomRenderer extends Renderer {

constructor(private _rootRenderer: CustomRootRenderer) {
super();
console.log('CustomRenderer created');
}

renderComponent(componentType: RenderComponentType): Renderer {
return this._rootRenderer.renderComponent(componentType);
}

selectRootElement(selector: string): Element {
console.log('selectRootElement', selector);
return new Element('Root');
}

createElement(parentElement: Element, name: string): Element {
console.log('createElement', 'parent: ' + parentElement, 'name: ' + name);
return new Element(name, parentElement);
}

createViewRoot(hostElement: Element): Element {
console.log('createViewRoot', 'host: ' + hostElement);
return hostElement;
}

createTemplateAnchor(parentElement: Element): Element {
console.log('createTemplateAnchor', 'parent: ' + parentElement);
return new Element('?');
}

createText(parentElement: Element, value: string): Element {
console.log('createText', 'parent: ' + parentElement, 'value: ' + value);
return new Element('text');
}

projectNodes(parentElement: Element, nodes: Element[]) {
console.log('projectNodes', 'parent: ' + parentElement, 'nodes: ' + nodes.map(node => node.toString()));
}

attachViewAfter(node: Element, viewRootNodes: Element[]) {
console.log('attachViewAfter', 'node: ' + node, 'viewRootNodes: ' + viewRootNodes.map(node => node.toString()));
}

detachView(viewRootNodes: Element[]) {
console.log('detachView', 'viewRootNodes: ' + viewRootNodes.map(node => node.toString()));
}

destroyView(hostElement: Element, viewAllNodes: Element[]) {
console.log('destroyView', 'host: ' + hostElement, 'viewAllNodes: ' + viewAllNodes.map(node => node.toString()));
}

setElementProperty(renderElement: Element, propertyName: string, propertyValue: any): void {
console.log('setElementProperty', 'element: ' + renderElement, 'name: ' + propertyName, 'value: ' + propertyValue);
}

setElementAttribute(renderElement: Element, attributeName: string, attributeValue: string): void {
console.log('setElementAttribute', 'element: ' + renderElement, 'name: ' + attributeName, 'value: ' + attributeValue);
return this.setElementProperty(renderElement, attributeName, attributeValue);
}

listen(renderElement: Element, eventName: string, callback: Function): Function {
console.log('listen', 'element: ' + renderElement, 'eventName: ' + eventName);
return function () { };
}

listenGlobal(target: string, eventName: string, callback: Function): Function {
console.log('listen', 'target: ' + target, 'eventName: ' + eventName);
return function () { };
}

// Used only in debug mode to serialize property changes to comment nodes,
// such as <template> placeholders.
setBindingDebugInfo(renderElement: Element, propertyName: string, propertyValue: string): void {
console.log('setBindingDebugInfo', 'element: ' + renderElement, 'name: ' + propertyName, 'value: ' + propertyValue);
}

setElementClass(renderElement: Element, className: string, isAdd: boolean): void {
console.log('setElementClass', 'className' + className, 'isAdd: ' + isAdd);
}

setElementStyle(renderElement: Element, styleName: string, styleValue: string): void {
console.log('setElementStyle', 'name: ' + styleName, 'value: ' + styleValue);
}

invokeElementMethod(renderElement: Element, methodName: string, args: Array<any>) {
console.log('invokeElementMethod', 'name: ' + methodName, 'args: ' + args);
}

setText(renderNode: Element, text: string): void {
console.log('setText', 'node: ' + renderNode, 'text: ' + text);
}
}

最佳答案

您可以查看 Dynamically import a stylesheet depending on the environment 的问题.所以我认为你可以尝试通过以下方式加载动态样式:

  • here 添加动态组件作为向导.
  • 或者通过文档对象应用样式:

    export class AppComponent
    {
    title = 'Dynamic load theme';
    constructor (@Inject(DOCUMENT) private document) { }

    lightTheme() {
    this.document.getElementById('theme').setAttribute('href', 'light-theme.css');
    }

    darkTheme() {
    this.document.getElementById('theme').setAttribute('href', 'dark-theme.css');
    }

    }

这是关于 Plunker 的一个简单示例.

希望对您有所帮助!

关于angular - 扩展 Angular 4 通用渲染器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46204428/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com