- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我显示来自 JointJS 演示的 uml 图 https://github.com/clientIO/joint/tree/master/demo/umlcd在 Angular 8 中,我收到错误: joint.shapes.uml.js:13 Uncaught TypeError: Cannot read property 'Generic' of undefined
在 joint.shapes.uml.js:13
在 joint.shapes.uml.js:280
joint.shapes.uml.js:https://github.com/clientIO/joint/blob/master/dist/joint.shapes.uml.js
我做错了什么?
这是我的代码:
Angular.json
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"version": 1,
"newProjectRoot": "projects",
"projects": {
"Inspector": {
"projectType": "application",
"schematics": {},
"root": "",
"sourceRoot": "src",
"prefix": "app",
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
"outputPath": "dist/Inspector",
"index": "src/index.html",
"main": "src/main.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.app.json",
"aot": false,
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css",
"./node_modules/jointjs/dist/joint.css",
"./src/app/shared/umlcd.css"
],
"scripts": [
"./node_modules/jquery/dist/jquery.js",
"./node_modules/lodash/lodash.js",
"./node_modules/backbone/backbone.js",
"./plugin/joint.shapes.uml.js",
"./node_modules/jointjs/dist/joint.js"
]
},
"configurations": {
"production": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
],
"optimization": true,
"outputHashing": "all",
"sourceMap": false,
"extractCss": true,
"namedChunks": false,
"aot": true,
"extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true,
"budgets": [
{
"type": "initial",
"maximumWarning": "2mb",
"maximumError": "5mb"
},
{
"type": "anyComponentStyle",
"maximumWarning": "6kb",
"maximumError": "10kb"
}
]
}
}
},
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"browserTarget": "Inspector:build"
},
"configurations": {
"production": {
"browserTarget": "Inspector:build:production"
}
}
},
"extract-i18n": {
"builder": "@angular-devkit/build-angular:extract-i18n",
"options": {
"browserTarget": "Inspector:build"
}
},
"test": {
"builder": "@angular-devkit/build-angular:karma",
"options": {
"main": "src/test.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.spec.json",
"karmaConfig": "karma.conf.js",
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css"
],
"scripts": []
}
},
"lint": {
"builder": "@angular-devkit/build-angular:tslint",
"options": {
"tsConfig": [
"tsconfig.app.json",
"tsconfig.spec.json",
"e2e/tsconfig.json"
],
"exclude": [
"**/node_modules/**"
]
}
},
"e2e": {
"builder": "@angular-devkit/build-angular:protractor",
"options": {
"protractorConfig": "e2e/protractor.conf.js",
"devServerTarget": "Inspector:serve"
},
"configurations": {
"production": {
"devServerTarget": "Inspector:serve:production"
}
}
}
}
}},
"defaultProject": "Inspector"
}
带有 jointJS 演示代码的 typescript 文件:
(我必须在演示代码中进行更改,例如:每个图实体必须具有属性和方法数组,并且属性 name 必须是 String [] 类型而不是 String。如果没有这些更改演示代码不起作用。)
import { Component, OnInit} from '@angular/core';
import * as _ from 'lodash';
import * as joint from 'jointjs';
@Component({
selector: 'app-demo',
templateUrl: './demo.component.html',
styleUrls: ['./demo.component.css']
})
export class DemoComponent implements OnInit{
constructor() { }
ngOnInit() {
this.createDiagram();
}
private createDiagram(): void {
var graph = new joint.dia.Graph();
new joint.dia.Paper({
el: document.getElementById('paper'),
width: 1000,
height: 600,
model: graph,
gridSize: 1,
});
var uml = joint.shapes.uml;
var classes = {
mammal: new uml.Interface({
position: { x:300 , y: 150 },
size: { width: 240, height: 100 },
name: ['Mammal'],
attributes: ['dob: Date'],
methods: ['+ setDateOfBirth(dob: Date): Void','+ getAgeAsDays(): Numeric'],
attrs: {
'.uml-class-name-rect': {
fill: '#feb662',
stroke: '#000000',
'stroke-width': 0.5
},
'.uml-class-attrs-rect': {
fill: '#fdc886',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-rect': {
fill: '#fdc886',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-attrs-text': {
ref: '.uml-class-attrs-rect',
'ref-y': 0.5,
'y-alignment': 'middle'
},
'.uml-class-methods-text': {
ref: '.uml-class-methods-rect',
'ref-y': 0.5,
'y-alignment': 'middle'
}
}
}),
person: new uml.Abstract({
position: { x:300 , y: 300 },
size: { width: 260, height: 100 },
name: ['Person'],
attributes: ['firstName: String','lastName: String'],
methods: ['+ setName(first: String, last: String): Void','+ getName(): String'],
attrs: {
'.uml-class-name-rect': {
fill: '#68ddd5',
stroke: '#ffffff',
'stroke-width': 0.5
},
'.uml-class-attrs-rect': {
fill: '#9687fe',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-rect': {
fill: '#9687fe',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-text, .uml-class-attrs-text': {
fill: '#fff'
}
}
}),
bloodgroup: new uml.Class({
position: { x:20 , y: 190 },
size: { width: 220, height: 100 },
name: ['BloodGroup'],
attributes: ['bloodGroup: String'],
methods: ['+ isCompatible(bG: String): Boolean'],
attrs: {
'.uml-class-name-rect': {
fill: '#ff8450',
stroke: '#fff',
'stroke-width': 0.5,
},
'.uml-class-attrs-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-attrs-text': {
ref: '.uml-class-attrs-rect',
'ref-y': 0.5,
'y-alignment': 'middle'
},
'.uml-class-methods-text': {
ref: '.uml-class-methods-rect',
'ref-y': 0.5,
'y-alignment': 'middle'
}
}
}),
address: new uml.Class({
position: { x:630 , y: 190 },
size: { width: 160, height: 100 },
name: ['Address'],
attributes: ['houseNumber: Integer','streetName: String','town: String','postcode: String'],
methods: [],
attrs: {
'.uml-class-name-rect': {
fill: '#ff8450',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-attrs-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-attrs-text': {
'ref-y': 0.5,
'y-alignment': 'middle'
}
}
}),
man: new uml.Class({
position: { x:200 , y: 500 },
size: { width: 180, height: 50 },
name: ['Man'],
attributes: [],
methods: [],
attrs: {
'.uml-class-name-rect': {
fill: '#ff8450',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-attrs-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
}
}
}),
woman: new uml.Class({
position: { x:450 , y: 500 },
size: { width: 180, height: 50 },
name: ['Woman'],
attributes: [],
methods: ['+ giveABrith(): Person []'],
attrs: {
'.uml-class-name-rect': {
fill: '#ff8450',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-attrs-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-rect': {
fill: '#fe976a',
stroke: '#fff',
'stroke-width': 0.5
},
'.uml-class-methods-text': {
'ref-y': 0.5,
'y-alignment': 'middle'
}
}
})
};
Object.keys(classes).forEach(function(key) {
graph.addCell(classes[key]);
});
var relations = [
new uml.Generalization({ source: { id: classes.man.id }, target: { id: classes.person.id }}),
new uml.Generalization({ source: { id: classes.woman.id }, target: { id: classes.person.id }}),
new uml.Implementation({ source: { id: classes.person.id }, target: { id: classes.mammal.id }}),
new uml.Aggregation({ source: { id: classes.person.id }, target: { id: classes.address.id }}),
new uml.Composition({ source: { id: classes.person.id }, target: { id: classes.bloodgroup.id }})
];
Object.keys(relations).forEach(function(key) {
graph.addCell(relations[key]);
});
}
}
最佳答案
在您的 angular.json
中,构建中包含的脚本顺序是错误的。
joint.shapes.uml.js
应在 joint.js
执行后执行。
正确顺序
"scripts": [
"./node_modules/jquery/dist/jquery.js",
"./node_modules/lodash/lodash.js",
"./node_modules/backbone/backbone.js",
"./node_modules/jointjs/dist/joint.js"
"./plugin/joint.shapes.uml.js",
]
关于javascript - 关节.shapes.uml.js : Uncaught TypeError: Cannot read property 'Generic' of undefined,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60310331/
您好,我很确定我的问题很愚蠢,但我无法弄清楚它对我的生活有何影响。我有这个家庭作业,它基本上是为了加强我们在类里面学到的关于多态性的知识(顺便说一下,这是 C++)。该程序的基础是一个名为 shape
我是新手,所以需要任何帮助,当我要求一个例子时,我的教授给我了这段代码,我希望有一个工作模型...... from numpy import loadtxt import numpy as np fr
CSS 形状边距 和 外型不适用于我的系统。我正在使用最新版本的 Chrome。我唯一能想到的是我的操作系统是 Windows 7。这应该是一个问题吗? 这是JSFiddle .但是,由于在您的系统上
#tf.shape(tensor)和tensor.shape()的区别 ?
我要求提示以下问题。如何从事件表添加到指定的单元格形状?当我知道名称但不知道如何为...中的每个形状实现论坛时,我可以添加形状 目前我有这样的事情: Sub loop() Dim a As Integ
我在 Excel 中有一个流程设计(使用形状、连接器等)。 我需要的是有一个矩阵,每个形状都有所有的前辈和所有的后继者。 在 VBA 中,为此我正在尝试执行以下操作: - 我列出了所有的连接器(Sha
我正在使用 JavaFX 编写一个教育应用程序,用户可以在其中绘制和操作贝塞尔曲线 Line、QuadCurve 和 CubicCurve。这些曲线应该能够用鼠标拖动。我有两种选择: 1- 使用类 L
我正在尝试绘制 pandas 系列中列的直方图 ('df_plot')。因为我希望 y 轴是百分比(而不是计数),所以我使用权重选项来实现这一点。正如您在下面的堆栈跟踪中发现的那样,权重数组和数据系列
我尝试在 opencv dnn 中实现一个 tensorflow 模型。这是我遇到的错误: OpenCV: Can't create layer "flatten_1/Shape" of type "
我目前正在用 Java 开发一款游戏,我一直在尝试弄清楚如何在 Canvas 上绘制一个形状(例如圆形),在不同的形状(例如正方形)之上,但是只绘制与正方形相交的圆的部分,类似于 Photoshop
import cv2 import numpy as np import sys import time import os cap = cv2.VideoCa
我已经成功创建了 Keras 序列模型并对其进行了一段时间的训练。现在我试图做出一些预测,但即使使用与训练阶段相同的数据,它也会失败。 我收到此错误:{ValueError}检查输入时出错:预期 em
我正在尝试逐行分解程序。 Y 是一个数据矩阵,但我找不到任何关于 .shape[0] 究竟做了什么的具体数据。 for i in range(Y.shape[0]): if Y[i] == -
我正在尝试运行代码,但它给了我这个错误: 行,列,_ = frame.shape AttributeError:“tuple”对象没有属性“shape” 我正在使用OpenCV和python 3.6,
我想在 JavaFx 中的 Pane 上显示形状。我正在使用从空间数据库中选择的 Oracle JGeometry 对象,它有一个方法 createShape() 但它返回 java.awt.Shap
在此代码中: import pandas as pd myj='{"columns":["tablename","alias_tablename","real_tablename","
我正在尝试将 API 结果应用于两列。 下面是我的虚拟数据框。不幸的是,这不是很容易重现,因为我使用的是带有 key 和密码的 API...这只是为了让您了解尺寸。 但我希望也许有人能发现一个明显的问
我的代码是: final String json = getObjectMapper().writeValueAsString(JsonView.with(graph) .onClas
a=np.arange(240).reshape(3,4,20) b=np.arange(12).reshape(3,4) c=np.zeros((3,4),dtype=int) x=np.arang
我正在尝试从张量中提取某些数据,但出现了奇怪的错误。在这里,我将尝试生成错误: a=np.random.randn(5, 10, 5, 5) a[:, [1, 6], np.triu_indices(
我是一名优秀的程序员,十分优秀!