>#### 旭日圖菜單
~~~
const sourceData = [{
id: "1470876252852527106",
parentId: "0",
children: [{
id: "1470876252852527107",
parentId: "1470876252852527106",
children: [{
id: "1470876252852527108",
parentId: "1470876252852527107",
children: [],
nodeName: "低頻",
},
{
id: "1470876252852527109",
parentId: "1470876252852527107",
children: [],
nodeName: "高頻",
},
],
nodeName: "基本面",
},
{
id: "1470876252852527110",
parentId: "1470876252852527106",
children: [{
id: "1470876252852527111",
parentId: "1470876252852527110",
children: [],
nodeName: "風險溢價",
},
{
id: "1470876252852527112",
parentId: "1470876252852527110",
children: [],
nodeName: "RAI",
},
{
id: "1470876252852527113",
parentId: "1470876252852527110",
children: [],
nodeName: "均線動量",
},
{
id: "1470876252852527114",
parentId: "1470876252852527110",
children: [],
nodeName: "資金",
},
],
nodeName: "市場趨勢",
},
],
nodeName: "債券",
},
{
id: "1470876252852527115",
parentId: "0",
children: [{
id: "1470876252852527116",
parentId: "1470876252852527115",
children: [{
id: "1470876252852527117",
parentId: "1470876252852527116",
children: [],
nodeName: "估值",
},
{
id: "1470876252852527118",
parentId: "1470876252852527116",
children: [],
nodeName: "盈利",
},
],
nodeName: "基本面",
},
{
id: "1470876252852527119",
parentId: "1470876252852527115",
children: [{
id: "1470876252852527120",
parentId: "1470876252852527119",
children: [],
nodeName: "風險溢價",
},
{
id: "1470876252852527121",
parentId: "1470876252852527119",
children: [],
nodeName: "成交量",
},
{
id: "1470876252852527122",
parentId: "1470876252852527119",
children: [],
nodeName: "機構行為",
},
],
nodeName: "市場趨勢",
},
{
id: "1470876252852527123",
parentId: "1470876252852527115",
children: [],
nodeName: "尾部信號",
},
],
nodeName: "股票",
},
{
id: "1470876252852527124",
parentId: "0",
children: [],
nodeName: "股票風格",
},
];
const gapDeg = 3;
function getDepthAndSum(arr, depth, endNodeSum) {
var flag = false;
var temp = [];
for (let i = 0; i < arr.length; i++) {
arr[i].name = arr[i].nodeName;
if (arr[i].children instanceof Array) {
// 判斷是否是數組
for (let j = 0; j < arr[i].children.length; j++) {
temp.push(arr[i].children[j]); // 解析出arr下第一層
}
flag = true;
if (arr[i].children.length === 0) {
endNodeSum++;
arr[i].value = 1;
}
}
}
if (flag) {
// 如果還有數組,則繼續解析,直到最后一層有不為數組為止
depth++;
return getDepthAndSum(temp, depth, endNodeSum);
} else {
return {
depth,
endNodeSum
};
}
}
const {
depth,
endNodeSum
} = getDepthAndSum(sourceData, 0, 0);
const realData = [];
const list = ["債券", "股票風格", "股票"];
list.forEach((name) => {
const el = sourceData.find(({
nodeName
}) => nodeName === name);
realData.push(el);
realData.push({
value: (gapDeg / 360) * endNodeSum,
itemStyle: {
opacity: 0,
color: "transparent"
},
cursor: "auto",
type: "gap",
});
});
function handleSunburstData(arr, level, func) {
arr.forEach((item) => {
func(item, level);
if (item.children && item.children.length > 0 && item.type !== "hideItem") {
handleSunburstData(item.children, level + 1, func);
}
});
}
function getSunburstData(index) {
const res = [];
const cloneData = JSON.parse(JSON.stringify(realData));
let dataIndex = 0;
handleSunburstData(cloneData, 1, (item, level) => {
dataIndex++;
if (item.type === "gap") {
return;
}
if (index === 0) {
if (!item.children || (level < depth && item.children.length === 0)) {
item.dataIndex = dataIndex;
item.label = {
show: false
};
item.itemStyle = {
opacity: 0
};
item.emphasis = {
label: {
show: false
}
};
item.type = "hideItem";
if (level === 1) {
item.seriesIndex = 1;
item.children = [{
id: item.id,
value: 1,
dataIndex: dataIndex,
seriesIndex: 1,
itemStyle: {
opacity: 0
},
children: [{
id: item.id,
value: 1,
dataIndex: dataIndex,
seriesIndex: 1,
itemStyle: {
opacity: 0
},
}, ],
}, ];
}
if (level === 2) {
item.seriesIndex = 2;
item.children = [{
id: item.id,
value: 1,
dataIndex: dataIndex,
seriesIndex: 2,
itemStyle: {
opacity: 0
},
}, ];
}
}
} else {
if (level !== index || item.children.length !== 0) {
item.label = {
show: false
};
item.itemStyle = {
opacity: 0
};
item.cursor = "auto";
item.emphasis = {
label: {
show: false
}
};
}
}
});
return cloneData;
}
option = {
title: {
text: '旭日圖菜單',
left: 'center',
top: '10px',
textStyle: {
color: '#ffffff'
}
},
toolbox: {
feature: {
saveAsImage: {}
}
},
backgroundColor: "#0f375f",
series: [{
type: "sunburst",
radius: ["20%", "80%"],
center: ["50%", "50%"],
data: getSunburstData(0),
emphasis: {
focus: "none",
},
sort: null,
label: {
rotate: 0,
},
nodeClick: false,
z: 3,
startAngle: 90 - gapDeg / 2,
},
{
type: "sunburst",
radius: ["20%", "200%"],
center: ["50%", "50%"],
data: getSunburstData(1),
emphasis: {
focus: "none",
},
sort: null,
label: {
rotate: 0,
},
nodeClick: false,
silent: true,
startAngle: 90 - gapDeg / 2,
},
{
type: "sunburst",
radius: ["0%", "120%"],
center: ["50%", "50%"],
data: getSunburstData(2),
emphasis: {
focus: "none",
},
sort: null,
label: {
rotate: 0,
},
nodeClick: false,
silent: true,
startAngle: 90 - gapDeg / 2,
},
],
};
myChart.on("mouseover", function (params) {
// 控制臺打印數據的名稱
if (params.data.dataIndex) {
const {
seriesIndex,
dataIndex
} = params.data;
myChart.dispatchAction({
type: "highlight",
seriesIndex: seriesIndex,
dataIndex: dataIndex,
});
}
});
myChart.on("mouseout", function (params) {
// 控制臺打印數據的名稱
if (params.data.dataIndex) {
const {
seriesIndex,
dataIndex
} = params.data;
myChart.dispatchAction({
type: "downplay",
seriesIndex: seriesIndex,
dataIndex: dataIndex,
});
}
});
myChart.on("click", function (params) {
// 控制臺打印數據的名稱
console.log(params.data.id);
});
~~~
>#### 效果圖

<hr>
>#### 中心標題
~~~
var giftImageUrl =
"";
option = {
backgroundColor: "#0f375f",
tooltip: {
trigger: "item",
formatter: "{a} <br/>{b}: {c} ({d}%)",
},
toolbox: {
feature: {
saveAsImage: {}
}
},
graphic: {
elements: [{
type: "image",
style: {
image: giftImageUrl,
width: 100,
height: 100,
},
left: "center",
top: "center",
}, ],
},
title: {
text: "類型分析",
left: "center",
top: "55%",
padding: [24, 0],
textStyle: {
color: "#fff",
fontSize: 20,
align: "center",
},
},
legend: {
orient: "horizontal",
icon: "circle",
bottom: 20,
x: "center",
data: [
"社工",
"養老護理員",
"康復師",
"心理咨詢師",
"醫生",
"護士",
"管理人員",
"后勤人員",
"其他人員",
],
textStyle: {
color: "#fff",
},
},
series: [{
name: "人員類型",
type: "pie",
hoverAnimation: false,
legendHoverLink: false,
radius: ["38%", "45%"],
color: [
"#006495",
"#1D5F84",
"#255C6D",
"#3C5C67",
"#40486C",
"#3F3C73",
"#403D84",
"#1F3A8D",
"#0B3B77",
],
label: {
normal: {
position: "inner",
},
},
labelLine: {
normal: {
show: false,
},
},
tooltip: {
show: false,
},
data: [{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
{
value: 100,
name: "",
},
],
},
{
name: "人員類型",
type: "pie",
radius: ["43%", "55%"],
color: [
"#00FFFF",
"#44EAB1",
"#7BDD43",
"#FEBE12",
"#EBEC2F",
"#FF7C44",
"#FA3E5F",
"#6635EF",
"#FFAFDA",
],
labelLine: {
normal: {
show: true,
length: 20,
length2: 20,
lineStyle: {
width: 2,
},
},
},
label: {
normal: {
formatter: "{c|{c}}\n{hr|}\n{d|{d}%}",
rich: {
b: {
fontSize: 20,
color: "#12EABE",
align: "left",
padding: 4,
},
hr: {
borderColor: "#12EABE",
width: "100%",
borderWidth: 2,
height: 0,
},
d: {
fontSize: 20,
color: "#fff",
align: "left",
padding: 4,
},
c: {
fontSize: 20,
color: "#fff",
align: "left",
padding: 4,
},
},
},
},
data: [{
value: 100,
name: "社工",
},
{
value: 100,
name: "養老護理員",
},
{
value: 100,
name: "康復師",
},
{
value: 100,
name: "心理咨詢師",
},
{
value: 100,
name: "醫生",
},
{
value: 100,
name: "護士",
},
{
value: 100,
name: "管理人員",
},
{
value: 100,
name: "后勤人員",
},
{
value: 100,
name: "其他人員",
},
],
},
],
};
~~~
>#### 效果圖

<hr>
>#### 分類嵌套
~~~
option = {
title: {
text: "分類嵌套",
subtext: "",
top: '10px',
left: "center",
textStyle: {
color: "#fff",
fontSize: 18,
},
},
toolbox: {
feature: {
saveAsImage: {}
}
},
backgroundColor: "#0f375f",
tooltip: {
trigger: "item",
formatter: "{a} <br/>{b}:({d}%)",
},
series: [{
name: "事業線",
type: "pie",
radius: ["10%", "50%"],
color: ["#ec5d51", "#59abe1", "#f4cf42", "#3dc6a8"],
label: {
normal: {
position: "inner",
},
},
data: [{
value: 11,
name: "APP事業部",
},
{
value: 15,
name: "家長事業部",
},
{
value: 9,
name: "TV事業部",
},
{
value: 9,
name: "公共",
},
],
},
{
name: "分組",
type: "pie",
radius: ["54%", "72%"],
color: [
"#a0dca0",
"#60bbb6",
"#f78db3",
"#feadac",
"#fae395",
"#91d4e5",
"#8eb3e8",
],
label: {
normal: {
formatter: "{b}\n{d}%",
},
},
data: [{
value: 6,
name: "2D線",
},
{
value: 5,
name: "3D線",
},
{
value: 8,
name: "寶寶產品大全",
},
{
value: 7,
name: "大全產品線",
},
{
value: 9,
name: "TV事業部",
},
{
value: 9,
name: "公共",
},
],
},
],
};
~~~
>#### 效果圖

<hr>
>#### 高校學生類別分類
~~~
option = {
tooltip: {
formatter: (params) => {
let str = '';
params.treePathInfo.forEach((item, index) => {
if (index > 0 && index < params.treePathInfo.length - 1) {
str += item.name + '-';
} else if (index !== 0) {
str += item.name + ':' + item.value;
}
});
return str;
},
},
title: {
text: "高校學生類別分類",
subtext: "",
top: '10px',
left: "center",
textStyle: {
color: "#fff",
fontSize: 18,
},
},
toolbox: {
feature: {
saveAsImage: {}
}
},
backgroundColor: "#0f375f",
color: [
'#1B95E6',
'#6674C4',
'#FF95D2',
'#6BBEAC',
'#FACF5B',
'#3DC0E4',
'#0DCB74',
'#8368D9',
'#AF65BE',
'#4C6471',
'#1C436F',
'#E57B88',
'#F4B246',
'#A77C56',
],
series: {
type: 'sunburst',
data: [{
name: '碩士',
children: [{
name: '全日制',
children: [{
name: '學術型',
value: 11,
},
{
name: '專業型',
value: 44,
},
],
},
{
name: '非全日制',
children: [{
name: '專業型',
value: 66,
}, ],
},
],
},
{
name: '博士',
children: [{
name: '全日制',
children: [{
name: '學術型',
value: 22,
}, ],
},
{
name: '非全日制',
children: [{
name: '學術型',
value: 33,
},
{
name: '專業型',
value: 55,
},
],
},
],
},
],
radius: ['10%', '70%'],
label: {
rotate: 0,
},
itemStyle: {
borderColor: '#fff',
borderWidth: 1,
borderRadius: 6,
},
emphasis: {
focus: 'ancestor',
},
levels: [{
// 留給數據下鉆點的空白配置
itemStyle: {
color: '#fff',
},
radius: ['10%', '10%'],
},
{
radius: ['10%', '35%'],
},
{
radius: ['37%', '62%'],
itemStyle: {
opacity: 0.95
}
},
{
radius: ['64%', '70%'],
label: {
position: 'outside',
distance: 12,
},
itemStyle: {
opacity: 0.9
},
downplay: {
label: {
opacity: 0.5,
},
},
},
],
},
};
~~~
>#### 效果圖

<hr>
- html
- 頭部標簽
- canvas
- md
- DOM
- git常用命令
- css
- 網站
- 默認
- 前綴
- 文本
- 圖片
- 選擇器
- 滾動條
- 強制橫屏
- 響應式
- 動畫
- animation(動畫)
- transition(過渡)
- transform(變形)
- translate(移動)
- 漸變
- 鼠標
- 自定義 Web 字體
- 可視化
- echarts
- 折線圖
- 區域顏色標識
- 分段顯示不同顏色
- 柱狀圖
- 子彈圖
- 分組、柱體寬度、指示器寬度
- 圓角
- 頂部顯示文字
- 雙軸柱狀折線圖
- 雙軸雙列柱狀圖
- 單個柱狀圖
- 多縱向坐標
- 走勢圖
- 橫向百分比
- 最大值和最小值
- 餅圖
- 嵌套
- 分組顯示
- 餅圖結合柱狀圖
- 折線結合餅圖
- 關系圖
- 樹圖
- 地圖
- 標點
- 選中
- 常用
- 圖片超出可拖拽
- 百度導航
- 短信驗證碼倒計時
- video
- TS
- 未整理
- 消失的邊界線問題
- 跟隨
- js
- 兼容
- 數組去重
- 解析 URL 參數為對象
- 圖片懶加載
- 正則
- Photoshop
- 快捷鍵
- 混合模式
- vscode
- vue
- 指令