提交 f102d8c3 编写于 作者: fxy060608's avatar fxy060608

wip(app): uni-app-plus

上级 1e6f6be8
import { UniNodeJSON } from '@dcloudio/uni-shared' import { UniNodeJSON } from '@dcloudio/uni-shared'
import { import { createPageNode } from '../../../src/service/framework/dom/Page'
ACTION_TYPE_INSERT,
ACTION_TYPE_REMOVE,
ACTION_TYPE_REMOVE_ATTRIBUTE,
ACTION_TYPE_SET_ATTRIBUTE,
ACTION_TYPE_SET_TEXT,
createPageNode,
InsertAction,
SetAttributeAction,
} from '../../../src/service/framework/dom/Page'
import { import {
createElement, createElement,
createTextNode, createTextNode,
} from '../../../../uni-app-vue/lib/service.runtime.esm' } from '../../../../uni-app-vue/lib/service.runtime.esm'
import {
InsertAction,
ACTION_TYPE_INSERT,
SetAttributeAction,
ACTION_TYPE_SET_ATTRIBUTE,
ACTION_TYPE_REMOVE_ATTRIBUTE,
ACTION_TYPE_SET_TEXT,
ACTION_TYPE_REMOVE,
} from '../../../src/PageAction'
describe('dom', () => { describe('dom', () => {
const pageId = 1 const pageId = 1
const root = createPageNode(pageId, { const root = createPageNode(pageId, {
route: 'pages/index/index',
version: 1, version: 1,
locale: 'zh_CN', locale: 'zh_CN',
disableScroll: false, disableScroll: false,
......
...@@ -11,6 +11,7 @@ import { ...@@ -11,6 +11,7 @@ import {
import { createPageNode } from '../../src/service/framework/dom/Page' import { createPageNode } from '../../src/service/framework/dom/Page'
const defaultPageNodeOptions = { const defaultPageNodeOptions = {
route: 'pages/index/index',
version: 1, version: 1,
locale: 'zh_CN', locale: 'zh_CN',
disableScroll: false, disableScroll: false,
...@@ -55,7 +56,6 @@ describe('vue', () => { ...@@ -55,7 +56,6 @@ describe('vue', () => {
} }
const pageNode = createPageNode(1, defaultPageNodeOptions, true) const pageNode = createPageNode(1, defaultPageNodeOptions, true)
createApp(Page).mount(pageNode as unknown as Element) createApp(Page).mount(pageNode as unknown as Element)
pageNode.mounted()
show.value = false show.value = false
handleClick = null handleClick = null
nextTick(() => { nextTick(() => {
......
...@@ -818,6 +818,84 @@ ...@@ -818,6 +818,84 @@
function formatLog(module, ...args) { function formatLog(module, ...args) {
return `[${Date.now()}][${module}]\uFF1A${args.map((arg) => JSON.stringify(arg)).join(" ")}`; return `[${Date.now()}][${module}]\uFF1A${args.map((arg) => JSON.stringify(arg)).join(" ")}`;
} }
const ATTR_MAP = {
class: ".c",
style: ".s",
onClick: ".e0",
onChange: ".e1",
onInput: ".e2",
onLoad: ".e3",
onError: ".e4",
onTouchstart: ".e5",
onTouchmove: ".e6",
onTouchcancel: ".e7",
onTouchend: ".e8",
onLongpress: ".e9",
onTransitionend: ".ea",
onAnimationstart: ".eb",
onAnimationiteration: ".ec",
onAnimationend: ".ed",
onTouchforcechange: ".ee"
};
const COMPONENT_MAP = {
VIEW: 1,
IMAGE: 2,
TEXT: 3,
"#text": 4,
"#comment": 5,
NAVIGATOR: 6,
FORM: 7,
BUTTON: 8,
INPUT: 9,
LABEL: 10,
RADIO: 11,
CHECKBOX: 12,
"CHECKBOX-GROUP": 13,
AD: 14,
AUDIO: 15,
CAMERA: 16,
CANVAS: 17,
"COVER-IMAGE": 18,
"COVER-VIEW": 19,
EDITOR: 20,
"FUNCTIONAL-PAGE-NAVIGATOR": 21,
ICON: 22,
"RADIO-GROUP": 23,
"LIVE-PLAYER": 24,
"LIVE-PUSHER": 25,
MAP: 26,
"MOVABLE-AREA": 27,
"MOVABLE-VIEW": 28,
"OFFICIAL-ACCOUNT": 29,
"OPEN-DATA": 30,
PICKER: 31,
"PICKER-VIEW": 32,
"PICKER-VIEW-COLUMN": 33,
PROGRESS: 34,
"RICH-TEXT": 35,
"SCROLL-VIEW": 36,
SLIDER: 37,
SWIPER: 38,
"SWIPER-ITEM": 39,
SWITCH: 40,
TEXTAREA: 41,
VIDEO: 42,
"WEB-VIEW": 43
};
const DECODED_ATTR_MAP = /* @__PURE__ */ Object.keys(ATTR_MAP).reduce((map, name) => {
map[ATTR_MAP[name]] = name;
return map;
}, Object.create(null));
function decodeAttr(name) {
return DECODED_ATTR_MAP[name] || name;
}
const DECODED_COMPONENT_ARR = /* @__PURE__ */ Object.keys(COMPONENT_MAP).reduce((arr, name) => {
arr.push(name.toLowerCase());
return arr;
}, [""]);
function decodeTag(tag) {
return DECODED_COMPONENT_ARR[tag] || tag;
}
const E = function() { const E = function() {
}; };
E.prototype = { E.prototype = {
...@@ -2593,6 +2671,49 @@ ...@@ -2593,6 +2671,49 @@
} }
const ACTION_TYPE_PAGE_CREATE = 1; const ACTION_TYPE_PAGE_CREATE = 1;
const ACTION_TYPE_PAGE_CREATED = 2; const ACTION_TYPE_PAGE_CREATED = 2;
const ACTION_TYPE_CREATE = 3;
const ACTION_TYPE_INSERT = 4;
const ACTION_TYPE_REMOVE = 5;
const ACTION_TYPE_SET_ATTRIBUTE = 6;
const ACTION_TYPE_REMOVE_ATTRIBUTE = 7;
const ACTION_TYPE_SET_TEXT = 8;
const elements = new Map();
function $(id) {
return elements.get(id);
}
function createElement(id, tag) {
const element = document.createElement(decodeTag(tag));
elements.set(id, element);
return element;
}
function setElementAttr(element, name, value) {
element.setAttribute(decodeAttr(name), value);
}
function onNodeCreate(id, tag) {
return createElement(id, decodeTag(tag));
}
function onNodeInsert(nodeId, parentNodeId, refNodeId, nodeJson) {
const element = $(nodeId);
$(parentNodeId).insertBefore(initElement(element, nodeJson), $(refNodeId));
}
function initElement(element, { a, s }) {
initAttribute(element, a);
return element;
}
function initAttribute(element, attr) {
if (!attr) {
return;
}
Object.keys(attr).forEach((name) => setElementAttr(element, name, attr[name]));
}
function onNodeRemove(nodeId, parentNodeId) {
}
function onNodeRemoveAttr(nodeId, name) {
}
function onNodeSetAttr(nodeId, name, value) {
}
function onNodeSetText(nodeId, text) {
}
function onPageCreate({ function onPageCreate({
route, route,
disableScroll, disableScroll,
...@@ -2648,6 +2769,18 @@ ...@@ -2648,6 +2769,18 @@
return onPageCreate(action[1]); return onPageCreate(action[1]);
case ACTION_TYPE_PAGE_CREATED: case ACTION_TYPE_PAGE_CREATED:
return onPageCreated(); return onPageCreated();
case ACTION_TYPE_CREATE:
return onNodeCreate(action[1], action[2]);
case ACTION_TYPE_INSERT:
return onNodeInsert(action[1], action[2], action[3], action[4]);
case ACTION_TYPE_REMOVE:
return onNodeRemove(action[1], action[2]);
case ACTION_TYPE_SET_ATTRIBUTE:
return onNodeSetAttr(action[1], action[2], action[3]);
case ACTION_TYPE_REMOVE_ATTRIBUTE:
return onNodeRemoveAttr(action[1], action[2]);
case ACTION_TYPE_SET_TEXT:
return onNodeSetText(action[1], action[2]);
} }
}); });
} }
......
import { onNodeCreate } from './view/framework/subscriber/vdom/onNodeCreate'
import { onNodeInsert } from './view/framework/subscriber/vdom/onNodeInsert'
import { onNodeRemove } from './view/framework/subscriber/vdom/onNodeRemove'
import { onNodeRemoveAttr } from './view/framework/subscriber/vdom/onNodeRemoveAttr'
import { onNodeSetAttr } from './view/framework/subscriber/vdom/onNodeSetAttr'
import { onNodeSetText } from './view/framework/subscriber/vdom/onNodeSetText'
export const ACTION_TYPE_PAGE_CREATE = 1 export const ACTION_TYPE_PAGE_CREATE = 1
export const ACTION_TYPE_PAGE_CREATED = 2 export const ACTION_TYPE_PAGE_CREATED = 2
export const ACTION_TYPE_CREATE = 3 export const ACTION_TYPE_CREATE = 3
...@@ -27,40 +34,32 @@ export type PageCreatedAction = [typeof ACTION_TYPE_PAGE_CREATED] ...@@ -27,40 +34,32 @@ export type PageCreatedAction = [typeof ACTION_TYPE_PAGE_CREATED]
export type CreateAction = [ export type CreateAction = [
typeof ACTION_TYPE_CREATE, typeof ACTION_TYPE_CREATE,
number, // nodeId ...Parameters<typeof onNodeCreate>
string | number //nodeName
] ]
export type InsertAction = [ export type InsertAction = [
typeof ACTION_TYPE_INSERT, typeof ACTION_TYPE_INSERT,
number, // nodeId ...Parameters<typeof onNodeInsert>
number, // parentNodeId
number, // index
Record<string, any> // Element JSON
] ]
export type RemoveAction = [ export type RemoveAction = [
typeof ACTION_TYPE_REMOVE, typeof ACTION_TYPE_REMOVE,
number, // nodeId ...Parameters<typeof onNodeRemove>
number // parentNodeId
] ]
export type SetAttributeAction = [ export type SetAttributeAction = [
typeof ACTION_TYPE_SET_ATTRIBUTE, typeof ACTION_TYPE_SET_ATTRIBUTE,
number, // nodeId ...Parameters<typeof onNodeSetAttr>
string, // attribute name
unknown // attribute value
] ]
export type RemoveAttributeAction = [ export type RemoveAttributeAction = [
typeof ACTION_TYPE_REMOVE_ATTRIBUTE, typeof ACTION_TYPE_REMOVE_ATTRIBUTE,
number, // nodeId ...Parameters<typeof onNodeRemoveAttr>
string // attribute name
] ]
export type SetTextAction = [ export type SetTextAction = [
typeof ACTION_TYPE_SET_TEXT, typeof ACTION_TYPE_SET_TEXT,
number, // nodeId ...Parameters<typeof onNodeSetText>
string // text content
] ]
export type PageUpdateAction = export type PageUpdateAction =
......
import { once } from '@dcloudio/uni-shared' import { once } from '@dcloudio/uni-shared'
import { createApp, defineComponent } from 'vue' import { createApp, DefineComponent } from 'vue'
import { createPageNode } from '../dom/Page' import { createPageNode } from '../dom/Page'
import { setupPage } from './setup' import { setupPage } from './setup'
import __vuePlugin from '../plugin' import __vuePlugin from '../plugin'
import { PageNodeOptions } from '../../../PageAction' import { PageNodeOptions } from '../../../PageAction'
export type VueComponent = ReturnType<typeof defineComponent> export type VueComponent = DefineComponent
const pagesMap = new Map<string, ReturnType<typeof createFactory>>() const pagesMap = new Map<string, ReturnType<typeof createFactory>>()
......
import { import {
ACTION_TYPE_CREATE,
ACTION_TYPE_INSERT,
ACTION_TYPE_PAGE_CREATE, ACTION_TYPE_PAGE_CREATE,
ACTION_TYPE_PAGE_CREATED, ACTION_TYPE_PAGE_CREATED,
ACTION_TYPE_REMOVE,
ACTION_TYPE_REMOVE_ATTRIBUTE,
ACTION_TYPE_SET_ATTRIBUTE,
ACTION_TYPE_SET_TEXT,
PageAction, PageAction,
} from '../../../../PageAction' } from '../../../../PageAction'
import { onNodeCreate } from './onNodeCreate'
import { onNodeInsert } from './onNodeInsert'
import { onNodeRemove } from './onNodeRemove'
import { onNodeRemoveAttr } from './onNodeRemoveAttr'
import { onNodeSetAttr } from './onNodeSetAttr'
import { onNodeSetText } from './onNodeSetText'
import { onPageCreate } from './onPageCreate' import { onPageCreate } from './onPageCreate'
import { onPageCreated } from './onPageCreated' import { onPageCreated } from './onPageCreated'
...@@ -13,6 +25,18 @@ export function onVdSync(actions: PageAction[]) { ...@@ -13,6 +25,18 @@ export function onVdSync(actions: PageAction[]) {
return onPageCreate(action[1]) return onPageCreate(action[1])
case ACTION_TYPE_PAGE_CREATED: case ACTION_TYPE_PAGE_CREATED:
return onPageCreated() return onPageCreated()
case ACTION_TYPE_CREATE:
return onNodeCreate(action[1], action[2])
case ACTION_TYPE_INSERT:
return onNodeInsert(action[1], action[2], action[3], action[4])
case ACTION_TYPE_REMOVE:
return onNodeRemove(action[1], action[2])
case ACTION_TYPE_SET_ATTRIBUTE:
return onNodeSetAttr(action[1], action[2], action[3])
case ACTION_TYPE_REMOVE_ATTRIBUTE:
return onNodeRemoveAttr(action[1], action[2])
case ACTION_TYPE_SET_TEXT:
return onNodeSetText(action[1], action[2])
} }
}) })
} }
import { decodeTag } from '@dcloudio/uni-shared'
import { createElement } from './utils'
export function onNodeCreate(id: number, tag: string | number) {
return createElement(id, decodeTag(tag))
}
import { UniNodeJSON } from '@dcloudio/uni-shared'
import { $, setElementAttr } from './utils'
export function onNodeInsert(
nodeId: number,
parentNodeId: number,
refNodeId: number,
nodeJson: Partial<UniNodeJSON>
) {
const element = $(nodeId)
$(parentNodeId).insertBefore(initElement(element, nodeJson), $(refNodeId))
}
function initElement(element: Element, { a, s }: Partial<UniNodeJSON>) {
initAttribute(element, a)
// TODO style
return element
}
function initAttribute(element: Element, attr?: Record<string, unknown>) {
if (!attr) {
return
}
Object.keys(attr).forEach((name) => setElementAttr(element, name, attr[name]))
}
export function onNodeRemove(nodeId: number, parentNodeId: number) {}
export function onNodeRemoveAttr(nodeId: number, name: string) {}
export function onNodeSetAttr(nodeId: number, name: string, value: unknown) {}
export function onNodeSetText(nodeId: number, text: string) {}
import { decodeAttr, decodeTag } from '@dcloudio/uni-shared'
const elements = new Map<number, Element>()
export function $(id: number) {
return elements.get(id)!
}
export function createElement(id: number, tag: string) {
const element = document.createElement(decodeTag(tag))
elements.set(id, element)
return element
}
export function setElementAttr(element: Element, name: string, value: unknown) {
// TODO
element.setAttribute(decodeAttr(name), value as string)
}
...@@ -789,7 +789,7 @@ const DECODED_COMPONENT_ARR = /*#__PURE__*/ Object.keys(COMPONENT_MAP).reduce((a ...@@ -789,7 +789,7 @@ const DECODED_COMPONENT_ARR = /*#__PURE__*/ Object.keys(COMPONENT_MAP).reduce((a
return arr; return arr;
}, ['']); }, ['']);
function decodeTag(tag) { function decodeTag(tag) {
return DECODED_COMPONENT_ARR[tag] || tag; return (DECODED_COMPONENT_ARR[tag] || tag);
} }
function cache(fn) { function cache(fn) {
......
...@@ -45,7 +45,7 @@ export declare function decodeAttr(name: string): any; ...@@ -45,7 +45,7 @@ export declare function decodeAttr(name: string): any;
export declare function decodedQuery(query?: Record<string, any>): Record<string, string>; export declare function decodedQuery(query?: Record<string, any>): Record<string, string>;
export declare function decodeTag(tag: string | number): string | number; export declare function decodeTag(tag: string | number): string;
export declare const defaultRpx2Unit: { export declare const defaultRpx2Unit: {
unit: string; unit: string;
......
...@@ -785,7 +785,7 @@ const DECODED_COMPONENT_ARR = /*#__PURE__*/ Object.keys(COMPONENT_MAP).reduce((a ...@@ -785,7 +785,7 @@ const DECODED_COMPONENT_ARR = /*#__PURE__*/ Object.keys(COMPONENT_MAP).reduce((a
return arr; return arr;
}, ['']); }, ['']);
function decodeTag(tag) { function decodeTag(tag) {
return DECODED_COMPONENT_ARR[tag] || tag; return (DECODED_COMPONENT_ARR[tag] || tag);
} }
function cache(fn) { function cache(fn) {
......
...@@ -21,5 +21,5 @@ const DECODED_COMPONENT_ARR = /*#__PURE__*/ Object.keys(COMPONENT_MAP).reduce( ...@@ -21,5 +21,5 @@ const DECODED_COMPONENT_ARR = /*#__PURE__*/ Object.keys(COMPONENT_MAP).reduce(
) )
export function decodeTag(tag: string | number) { export function decodeTag(tag: string | number) {
return DECODED_COMPONENT_ARR[tag as number] || tag return (DECODED_COMPONENT_ARR[tag as number] || tag) as string
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册