1 line
82 KiB
HTML
1 line
82 KiB
HTML
<!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=2"><meta name="theme-color" content="#FFF"><link rel="apple-touch-icon" sizes="180x180" href="/images/apple-touch-icon.png"><link rel="icon" type="image/ico" sizes="32x32" href="/images/favicon.ico"><meta http-equiv="Cache-Control" content="no-transform"><meta http-equiv="Cache-Control" content="no-siteapp"><link rel="alternate" type="application/rss+xml" title="涛声依旧" href="https://hitoli.com/rss.xml"><link rel="alternate" type="application/atom+xml" title="涛声依旧" href="https://hitoli.com/atom.xml"><link rel="alternate" type="application/json" title="涛声依旧" href="https://hitoli.com/feed.json"><link rel="stylesheet" href="//fonts.googleapis.com/css?family=Mulish:300,300italic,400,400italic,700,700italic%7CFredericka%20the%20Great:300,300italic,400,400italic,700,700italic%7CNoto%20Serif%20JP:300,300italic,400,400italic,700,700italic%7CNoto%20Serif%20SC:300,300italic,400,400italic,700,700italic%7CInconsolata:300,300italic,400,400italic,700,700italic&display=swap&subset=latin,latin-ext"><link rel="stylesheet" href="/css/app.css?v=0.0.0"><meta name="keywords" content="KLineChart,K线,自定义指标"><link rel="canonical" href="https://hitoli.com/2023/01/31/KLineChart%E7%94%BB%E6%B3%A2%E6%AE%B5%E9%AB%98%E4%BD%8E%E4%BB%B7%E5%9B%BE/"><title>KLineChart 画波段高低价图 - KLineChart - 工作 | ☆∵∴Hito∴∵★ = 涛声依旧 = 天下事有难易乎?为之,则难者亦易矣</title><meta name="generator" content="Hexo 6.3.0"></head><body itemscope itemtype="http://schema.org/WebPage"><div id="loading"><div class="cat"><div class="body"></div><div class="head"><div class="face"></div></div><div class="foot"><div class="tummy-end"></div><div class="bottom"></div><div class="legs left"></div><div class="legs right"></div></div><div class="paw"><div class="hands left"></div><div class="hands right"></div></div></div></div><div id="container"><header id="header" itemscope itemtype="http://schema.org/WPHeader"><div class="inner"><div id="brand"><div class="pjax"><h1 itemprop="name headline">KLineChart 画波段高低价图</h1><div class="meta"><span class="item" title="创建时间:2023-01-31 09:44:00"><span class="icon"><i class="ic i-calendar"></i> </span><span class="text">发表于</span> <time itemprop="dateCreated datePublished" datetime="2023-01-31T09:44:00+08:00">2023-01-31</time> </span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i> </span><span class="text">本文字数</span> <span>5.8k</span> <span class="text">字</span> </span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i> </span><span class="text">阅读时长</span> <span>5 分钟</span></span></div></div></div><nav id="nav"><div class="inner"><div class="toggle"><div class="lines" aria-label="切换导航栏"><span class="line"></span> <span class="line"></span> <span class="line"></span></div></div><ul class="menu"><li class="item title"><a href="/" rel="start">☆∵∴Hito∴∵★</a></li></ul><ul class="right"><li class="item theme"><i class="ic i-sun"></i></li><li class="item search"><i class="ic i-search"></i></li></ul></div></nav></div><div id="imgs" class="pjax"><ul><li class="item" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giclh5u05ej20zk0m87df.jpg"></li><li class="item" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giciub8ja1j20zk0m81ky.jpg"></li><li class="item" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1gipevo9j1jj20zk0m8e81.jpg"></li><li class="item" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giclize41wj20zk0m87gk.jpg"></li><li class="item" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giclimtf7dj20zk0m8qav.jpg"></li><li class="item" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giclwuom7cj20zk0m8dvn.jpg"></li></ul></div></header><div id="waves"><svg class="waves" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 24 150 28" preserveAspectRatio="none" shape-rendering="auto"><defs><path id="gentle-wave" d="M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z"/></defs><g class="parallax"><use xlink:href="#gentle-wave" x="48" y="0"/><use xlink:href="#gentle-wave" x="48" y="3"/><use xlink:href="#gentle-wave" x="48" y="5"/><use xlink:href="#gentle-wave" x="48" y="7"/></g></svg></div><main><div class="inner"><div id="main" class="pjax"><div class="article wrap"><div class="breadcrumb" itemscope itemtype="https://schema.org/BreadcrumbList"><i class="ic i-home"></i> <span><a href="/">首页</a></span><i class="ic i-angle-right"></i> <span itemprop="itemListElement" itemscope itemtype="https://schema.org/ListItem"><a href="/categories/%E5%B7%A5%E4%BD%9C/" itemprop="item" rel="index" title="分类于 工作"><span itemprop="name">工作</span></a><meta itemprop="position" content="1"></span><i class="ic i-angle-right"></i> <span class="current" itemprop="itemListElement" itemscope itemtype="https://schema.org/ListItem"><a href="/categories/%E5%B7%A5%E4%BD%9C/KLineChart/" itemprop="item" rel="index" title="分类于 KLineChart"><span itemprop="name">KLineChart</span></a><meta itemprop="position" content="2"></span></div><article itemscope itemtype="http://schema.org/Article" class="post block" lang="zh-CN"><link itemprop="mainEntityOfPage" href="https://hitoli.com/2023/01/31/KLineChart%E7%94%BB%E6%B3%A2%E6%AE%B5%E9%AB%98%E4%BD%8E%E4%BB%B7%E5%9B%BE/"><span hidden itemprop="author" itemscope itemtype="http://schema.org/Person"><meta itemprop="image" content="/images/avatar.jpg"><meta itemprop="name" content="Hito Li"><meta itemprop="description" content="天下事有难易乎?为之,则难者亦易矣, 天生我材必有用"></span><span hidden itemprop="publisher" itemscope itemtype="http://schema.org/Organization"><meta itemprop="name" content="涛声依旧"></span><div class="body md" itemprop="articleBody"><h4 id="引言"><a class="anchor" href="#引言">#</a> 引言</h4><p>使用指定数据方式得到的线条总是不能达到想要的效果,一是阶梯线在价格发生变化的点存在倾斜,二是高低价的线很难完美显示,所以只能自己动手画了。代码仅供参考,如有错误的地方请指正!<br><img data-src="https://nas.hitoli.com:18014/images/2023/01/31/ee3c75b472c5869794e205747703d888.png" alt="ee3c75b472c5869794e205747703d888.png"></p><h4 id="模版代码"><a class="anchor" href="#模版代码">#</a> 模版代码</h4><figure class="highlight js"><figcaption data-lang="JavaScript"></figcaption><table><tr><td data-num="1"></td><td><pre><span class="token keyword">this</span><span class="token punctuation">.</span>chart<span class="token punctuation">.</span><span class="token function">addTechnicalIndicatorTemplate</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="2"></td><td><pre> <span class="token literal-property property">name</span><span class="token operator">:</span> <span class="token string">'BandHighLowInd'</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="3"></td><td><pre> <span class="token literal-property property">shortName</span><span class="token operator">:</span> <span class="token string">'波段高低价'</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="4"></td><td><pre> <span class="token literal-property property">calcParams</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token punctuation">{</span> <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">10</span> <span class="token punctuation">}</span><span class="token punctuation">]</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="5"></td><td><pre> <span class="token literal-property property">precision</span><span class="token operator">:</span> <span class="token number">2</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="6"></td><td><pre> <span class="token literal-property property">plots</span><span class="token operator">:</span> <span class="token punctuation">[</span></pre></td></tr><tr><td data-num="7"></td><td><pre> <span class="token punctuation">{</span> <span class="token literal-property property">key</span><span class="token operator">:</span> <span class="token string">'high'</span><span class="token punctuation">,</span> <span class="token literal-property property">title</span><span class="token operator">:</span> <span class="token string">'高: '</span><span class="token punctuation">,</span> <span class="token function-variable function">color</span><span class="token operator">:</span> <span class="token punctuation">(</span><span class="token parameter">data<span class="token punctuation">,</span> options</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span> <span class="token keyword">return</span> options<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span> <span class="token punctuation">}</span> <span class="token punctuation">}</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="8"></td><td><pre> <span class="token punctuation">{</span> <span class="token literal-property property">key</span><span class="token operator">:</span> <span class="token string">'low'</span><span class="token punctuation">,</span> <span class="token literal-property property">title</span><span class="token operator">:</span> <span class="token string">'低: '</span><span class="token punctuation">,</span> <span class="token function-variable function">color</span><span class="token operator">:</span> <span class="token punctuation">(</span><span class="token parameter">data<span class="token punctuation">,</span> options</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span> <span class="token keyword">return</span> options<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span> <span class="token punctuation">}</span> <span class="token punctuation">}</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="9"></td><td><pre> <span class="token punctuation">{</span> <span class="token literal-property property">key</span><span class="token operator">:</span> <span class="token string">'highLow'</span><span class="token punctuation">,</span> <span class="token literal-property property">title</span><span class="token operator">:</span> <span class="token string">'高低: '</span><span class="token punctuation">,</span> <span class="token function-variable function">color</span><span class="token operator">:</span> <span class="token punctuation">(</span><span class="token parameter">data<span class="token punctuation">,</span> options</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span> <span class="token keyword">return</span> options<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">2</span><span class="token punctuation">]</span> <span class="token punctuation">}</span> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="10"></td><td><pre> <span class="token punctuation">]</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="11"></td><td><pre> <span class="token function-variable function">calcTechnicalIndicator</span><span class="token operator">:</span> <span class="token punctuation">(</span><span class="token parameter">dataList<span class="token punctuation">,</span> <span class="token punctuation">{</span> params <span class="token punctuation">}</span></span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="12"></td><td><pre> <span class="token keyword">let</span> compareKlineSize <span class="token operator">=</span> params<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span> <span class="token comment">// 取前后 k 的范围</span></pre></td></tr><tr><td data-num="13"></td><td><pre> <span class="token keyword">let</span> highs <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="14"></td><td><pre> <span class="token keyword">let</span> lows <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="15"></td><td><pre> <span class="token keyword">let</span> highLows <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="16"></td><td><pre> <span class="token keyword">let</span> findHigh <span class="token comment">// 高低价当前查找标识</span></pre></td></tr><tr><td data-num="17"></td><td><pre> dataList<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token keyword">function</span> <span class="token punctuation">(</span><span class="token parameter">kLineData<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="18"></td><td><pre> <span class="token keyword">let</span> frontIndex <span class="token operator">=</span> i <span class="token operator">-</span> compareKlineSize</pre></td></tr><tr><td data-num="19"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>frontIndex <span class="token operator"><=</span> <span class="token number">0</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="20"></td><td><pre> frontIndex <span class="token operator">=</span> <span class="token number">0</span></pre></td></tr><tr><td data-num="21"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="22"></td><td><pre> <span class="token keyword">let</span> frontDatas <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="23"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>frontIndex <span class="token operator"><</span> i<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="24"></td><td><pre> frontDatas <span class="token operator">=</span> dataList<span class="token punctuation">.</span><span class="token function">slice</span><span class="token punctuation">(</span>frontIndex<span class="token punctuation">,</span> i<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="25"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="26"></td><td><pre> <span class="token keyword">let</span> afterIndex <span class="token operator">=</span> i <span class="token operator">+</span> compareKlineSize <span class="token operator">+</span> <span class="token number">1</span></pre></td></tr><tr><td data-num="27"></td><td><pre> <span class="token keyword">let</span> afterDatas <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="28"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>i <span class="token operator"><</span> dataList<span class="token punctuation">.</span>length <span class="token operator">-</span> <span class="token number">1</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="29"></td><td><pre> afterDatas <span class="token operator">=</span> dataList<span class="token punctuation">.</span><span class="token function">slice</span><span class="token punctuation">(</span>i <span class="token operator">+</span> <span class="token number">1</span><span class="token punctuation">,</span> afterIndex<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="30"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="31"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>frontDatas<span class="token punctuation">.</span>length <span class="token operator">===</span> compareKlineSize <span class="token operator">&&</span> afterDatas<span class="token punctuation">.</span>length <span class="token operator">===</span> compareKlineSize<span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 前后 K 线数据必须都找到要比较的条数</span></pre></td></tr><tr><td data-num="32"></td><td><pre> <span class="token keyword">let</span> high <span class="token operator">=</span> <span class="token keyword">null</span></pre></td></tr><tr><td data-num="33"></td><td><pre> <span class="token keyword">let</span> low <span class="token operator">=</span> <span class="token keyword">null</span></pre></td></tr><tr><td data-num="34"></td><td><pre> frontDatas<span class="token punctuation">.</span><span class="token function">concat</span><span class="token punctuation">(</span>afterDatas<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token keyword">function</span> <span class="token punctuation">(</span><span class="token parameter">kLineData<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 找出前后 k 线中的最高和最低价</span></pre></td></tr><tr><td data-num="35"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>high <span class="token operator">===</span> <span class="token keyword">null</span> <span class="token operator">||</span> kLineData<span class="token punctuation">.</span>high <span class="token operator">></span> high<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="36"></td><td><pre> high <span class="token operator">=</span> kLineData<span class="token punctuation">.</span>high</pre></td></tr><tr><td data-num="37"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="38"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>low <span class="token operator">===</span> <span class="token keyword">null</span> <span class="token operator">||</span> kLineData<span class="token punctuation">.</span>low <span class="token operator"><</span> low<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="39"></td><td><pre> low <span class="token operator">=</span> kLineData<span class="token punctuation">.</span>low</pre></td></tr><tr><td data-num="40"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="41"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="42"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>kLineData<span class="token punctuation">.</span>high <span class="token operator">></span> high<span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 当前 k 的高大于前后 k 中找出的高,则放入高价集合中</span></pre></td></tr><tr><td data-num="43"></td><td><pre> highs<span class="token punctuation">.</span><span class="token function">push</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="44"></td><td><pre> <span class="token literal-property property">time</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>timestamp<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="45"></td><td><pre> <span class="token literal-property property">value</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>high<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="46"></td><td><pre> <span class="token literal-property property">index</span><span class="token operator">:</span> i</pre></td></tr><tr><td data-num="47"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="48"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>findHigh<span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="49"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>findHigh <span class="token operator">&&</span> highLows<span class="token punctuation">[</span>highLows<span class="token punctuation">.</span>length <span class="token operator">-</span> <span class="token number">1</span><span class="token punctuation">]</span><span class="token punctuation">.</span>value <span class="token operator">!==</span> kLineData<span class="token punctuation">.</span>high<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="50"></td><td><pre> highLows<span class="token punctuation">.</span><span class="token function">push</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="51"></td><td><pre> <span class="token literal-property property">time</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>timestamp<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="52"></td><td><pre> <span class="token literal-property property">value</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>high<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="53"></td><td><pre> <span class="token literal-property property">index</span><span class="token operator">:</span> i</pre></td></tr><tr><td data-num="54"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="55"></td><td><pre> findHigh <span class="token operator">=</span> <span class="token boolean">false</span></pre></td></tr><tr><td data-num="56"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="57"></td><td><pre> <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="58"></td><td><pre> highLows<span class="token punctuation">.</span><span class="token function">push</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="59"></td><td><pre> <span class="token literal-property property">time</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>timestamp<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="60"></td><td><pre> <span class="token literal-property property">value</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>high<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="61"></td><td><pre> <span class="token literal-property property">index</span><span class="token operator">:</span> i</pre></td></tr><tr><td data-num="62"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="63"></td><td><pre> findHigh <span class="token operator">=</span> <span class="token boolean">false</span></pre></td></tr><tr><td data-num="64"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="65"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="66"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>kLineData<span class="token punctuation">.</span>low <span class="token operator"><</span> low<span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 当前 k 的低小于前后 k 中找出的低,则放入低价集合中</span></pre></td></tr><tr><td data-num="67"></td><td><pre> lows<span class="token punctuation">.</span><span class="token function">push</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="68"></td><td><pre> <span class="token literal-property property">time</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>timestamp<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="69"></td><td><pre> <span class="token literal-property property">value</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>low<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="70"></td><td><pre> <span class="token literal-property property">index</span><span class="token operator">:</span> i</pre></td></tr><tr><td data-num="71"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="72"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>findHigh<span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="73"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span>findHigh <span class="token operator">&&</span> highLows<span class="token punctuation">[</span>highLows<span class="token punctuation">.</span>length <span class="token operator">-</span> <span class="token number">1</span><span class="token punctuation">]</span><span class="token punctuation">.</span>value <span class="token operator">!==</span> kLineData<span class="token punctuation">.</span>low<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="74"></td><td><pre> highLows<span class="token punctuation">.</span><span class="token function">push</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="75"></td><td><pre> <span class="token literal-property property">time</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>timestamp<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="76"></td><td><pre> <span class="token literal-property property">value</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>low<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="77"></td><td><pre> <span class="token literal-property property">index</span><span class="token operator">:</span> i</pre></td></tr><tr><td data-num="78"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="79"></td><td><pre> findHigh <span class="token operator">=</span> <span class="token boolean">true</span></pre></td></tr><tr><td data-num="80"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="81"></td><td><pre> <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="82"></td><td><pre> highLows<span class="token punctuation">.</span><span class="token function">push</span><span class="token punctuation">(</span><span class="token punctuation">{</span></pre></td></tr><tr><td data-num="83"></td><td><pre> <span class="token literal-property property">time</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>timestamp<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="84"></td><td><pre> <span class="token literal-property property">value</span><span class="token operator">:</span> kLineData<span class="token punctuation">.</span>low<span class="token punctuation">,</span></pre></td></tr><tr><td data-num="85"></td><td><pre> <span class="token literal-property property">index</span><span class="token operator">:</span> i</pre></td></tr><tr><td data-num="86"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="87"></td><td><pre> findHigh <span class="token operator">=</span> <span class="token boolean">true</span></pre></td></tr><tr><td data-num="88"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="89"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="90"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="91"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="92"></td><td><pre> <span class="token keyword">let</span> high<span class="token punctuation">,</span> low<span class="token punctuation">,</span> highLow</pre></td></tr><tr><td data-num="93"></td><td><pre> <span class="token keyword">return</span> dataList<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">kLineData<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="94"></td><td><pre> <span class="token keyword">let</span> item <span class="token operator">=</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="95"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="96"></td><td><pre> highs<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">data</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="97"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>kLineData<span class="token punctuation">.</span>timestamp <span class="token operator">===</span> data<span class="token punctuation">.</span>time<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="98"></td><td><pre> high <span class="token operator">=</span> data<span class="token punctuation">.</span>value</pre></td></tr><tr><td data-num="99"></td><td><pre> item<span class="token punctuation">.</span>highOrigin <span class="token operator">=</span> <span class="token boolean">true</span></pre></td></tr><tr><td data-num="100"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="101"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="102"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>high<span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 持续先前的高,画出阶梯线</span></pre></td></tr><tr><td data-num="103"></td><td><pre> item<span class="token punctuation">.</span>timestamp <span class="token operator">=</span> kLineData<span class="token punctuation">.</span>timestamp</pre></td></tr><tr><td data-num="104"></td><td><pre> item<span class="token punctuation">.</span>high <span class="token operator">=</span> high</pre></td></tr><tr><td data-num="105"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="106"></td><td><pre> lows<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">data</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="107"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>kLineData<span class="token punctuation">.</span>timestamp <span class="token operator">===</span> data<span class="token punctuation">.</span>time<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="108"></td><td><pre> low <span class="token operator">=</span> data<span class="token punctuation">.</span>value</pre></td></tr><tr><td data-num="109"></td><td><pre> item<span class="token punctuation">.</span>lowOrigin <span class="token operator">=</span> <span class="token boolean">true</span></pre></td></tr><tr><td data-num="110"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="111"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="112"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>low<span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 持续先前的低,画出阶梯线</span></pre></td></tr><tr><td data-num="113"></td><td><pre> item<span class="token punctuation">.</span>timestamp <span class="token operator">=</span> kLineData<span class="token punctuation">.</span>timestamp</pre></td></tr><tr><td data-num="114"></td><td><pre> item<span class="token punctuation">.</span>low <span class="token operator">=</span> low</pre></td></tr><tr><td data-num="115"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="116"></td><td><pre> highLows<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">data</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="117"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>kLineData<span class="token punctuation">.</span>timestamp <span class="token operator">===</span> data<span class="token punctuation">.</span>time<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="118"></td><td><pre> highLow <span class="token operator">=</span> data<span class="token punctuation">.</span>value</pre></td></tr><tr><td data-num="119"></td><td><pre> item<span class="token punctuation">.</span>highLowOrigin <span class="token operator">=</span> <span class="token boolean">true</span></pre></td></tr><tr><td data-num="120"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="121"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="122"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>highLow<span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 持续先前的高低,方便 title 显示</span></pre></td></tr><tr><td data-num="123"></td><td><pre> item<span class="token punctuation">.</span>timestamp <span class="token operator">=</span> kLineData<span class="token punctuation">.</span>timestamp</pre></td></tr><tr><td data-num="124"></td><td><pre> item<span class="token punctuation">.</span>highLow <span class="token operator">=</span> highLow</pre></td></tr><tr><td data-num="125"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="126"></td><td><pre> <span class="token keyword">return</span> item</pre></td></tr><tr><td data-num="127"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="128"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">,</span></pre></td></tr><tr><td data-num="129"></td><td><pre> <span class="token function-variable function">render</span><span class="token operator">:</span> <span class="token punctuation">(</span><span class="token parameter"><span class="token punctuation">{</span> ctx<span class="token punctuation">,</span> dataSource<span class="token punctuation">,</span> viewport<span class="token punctuation">,</span> styles<span class="token punctuation">,</span> xAxis<span class="token punctuation">,</span> yAxis <span class="token punctuation">}</span></span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="130"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>dataSource<span class="token punctuation">.</span>technicalIndicatorDataList<span class="token punctuation">.</span>length <span class="token operator"><=</span> <span class="token number">0</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="131"></td><td><pre> <span class="token keyword">return</span></pre></td></tr><tr><td data-num="132"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="133"></td><td><pre> <span class="token keyword">let</span> x <span class="token operator">=</span> xAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="134"></td><td><pre> <span class="token keyword">let</span> high<span class="token punctuation">,</span> low<span class="token punctuation">,</span> highLow<span class="token punctuation">,</span> highLowX</pre></td></tr><tr><td data-num="135"></td><td><pre> dataSource<span class="token punctuation">.</span>technicalIndicatorDataList<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token keyword">function</span> <span class="token punctuation">(</span><span class="token parameter">data<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="136"></td><td><pre> <span class="token comment">// 画高线</span></pre></td></tr><tr><td data-num="137"></td><td><pre> ctx<span class="token punctuation">.</span>textBaseline <span class="token operator">=</span> <span class="token string">'middle'</span></pre></td></tr><tr><td data-num="138"></td><td><pre> ctx<span class="token punctuation">.</span>textAlign <span class="token operator">=</span> <span class="token string">'center'</span></pre></td></tr><tr><td data-num="139"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="140"></td><td><pre> ctx<span class="token punctuation">.</span>strokeStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="141"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>styles<span class="token punctuation">.</span>line <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="142"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="143"></td><td><pre> ctx<span class="token punctuation">.</span>strokeStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="144"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="145"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>high<span class="token punctuation">)</span> <span class="token operator">&&</span> data<span class="token punctuation">.</span>high <span class="token operator">!==</span> high<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="146"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">beginPath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="147"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">moveTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>high<span class="token punctuation">)</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="148"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">lineTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>high<span class="token punctuation">)</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="149"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">stroke</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="150"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">closePath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="151"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="152"></td><td><pre> high <span class="token operator">=</span> data<span class="token punctuation">.</span>high</pre></td></tr><tr><td data-num="153"></td><td><pre> <span class="token keyword">let</span> y <span class="token operator">=</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>high<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="154"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">beginPath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="155"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">moveTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> y<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="156"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">lineTo</span><span class="token punctuation">(</span>x <span class="token operator">+</span> viewport<span class="token punctuation">.</span>dataSpace<span class="token punctuation">,</span> y<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="157"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">stroke</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="158"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">closePath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="159"></td><td><pre> <span class="token comment">// 画低线</span></pre></td></tr><tr><td data-num="160"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="161"></td><td><pre> ctx<span class="token punctuation">.</span>strokeStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="162"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>styles<span class="token punctuation">.</span>line <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="163"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="164"></td><td><pre> ctx<span class="token punctuation">.</span>strokeStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="165"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="166"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>low<span class="token punctuation">)</span> <span class="token operator">&&</span> data<span class="token punctuation">.</span>low <span class="token operator">!==</span> low<span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="167"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">beginPath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="168"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">moveTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>low<span class="token punctuation">)</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="169"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">lineTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>low<span class="token punctuation">)</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="170"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">stroke</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="171"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">closePath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="172"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="173"></td><td><pre> low <span class="token operator">=</span> data<span class="token punctuation">.</span>low</pre></td></tr><tr><td data-num="174"></td><td><pre> y <span class="token operator">=</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>low<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="175"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">beginPath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="176"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">moveTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> y<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="177"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">lineTo</span><span class="token punctuation">(</span>x <span class="token operator">+</span> viewport<span class="token punctuation">.</span>dataSpace<span class="token punctuation">,</span> y<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="178"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">stroke</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="179"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">closePath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="180"></td><td><pre> <span class="token comment">// 画高低线</span></pre></td></tr><tr><td data-num="181"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>highLow<span class="token punctuation">)</span> <span class="token operator">&&</span> data<span class="token punctuation">.</span>highLowOrigin <span class="token operator">===</span> <span class="token boolean">true</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="182"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token function">isNotEmpty</span><span class="token punctuation">(</span>highLow<span class="token punctuation">)</span> <span class="token operator">&&</span> <span class="token function">isNotEmpty</span><span class="token punctuation">(</span>highLowX<span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="183"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="184"></td><td><pre> ctx<span class="token punctuation">.</span>strokeStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="185"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>styles<span class="token punctuation">.</span>line <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">2</span><span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="186"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">2</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="187"></td><td><pre> ctx<span class="token punctuation">.</span>strokeStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">2</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="188"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="189"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">beginPath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="190"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">moveTo</span><span class="token punctuation">(</span>highLowX<span class="token punctuation">,</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>highLow<span class="token punctuation">)</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="191"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">lineTo</span><span class="token punctuation">(</span>x<span class="token punctuation">,</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>highLow<span class="token punctuation">)</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="192"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">stroke</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="193"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">closePath</span><span class="token punctuation">(</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="194"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="195"></td><td><pre> highLow <span class="token operator">=</span> data<span class="token punctuation">.</span>highLow</pre></td></tr><tr><td data-num="196"></td><td><pre> highLowX <span class="token operator">=</span> x</pre></td></tr><tr><td data-num="197"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="198"></td><td><pre> <span class="token comment">// 画价格</span></pre></td></tr><tr><td data-num="199"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>data<span class="token punctuation">.</span>high <span class="token operator">!==</span> <span class="token keyword">undefined</span> <span class="token operator">&&</span> data<span class="token punctuation">.</span>highOrigin <span class="token operator">===</span> <span class="token boolean">true</span><span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 画高价</span></pre></td></tr><tr><td data-num="200"></td><td><pre> <span class="token keyword">let</span> text <span class="token operator">=</span> Number<span class="token punctuation">.</span><span class="token function">parseFloat</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>high<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">toFixed</span><span class="token punctuation">(</span><span class="token number">2</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="201"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="202"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>styles<span class="token punctuation">.</span>line <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="203"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="204"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="205"></td><td><pre> <span class="token keyword">let</span> offset <span class="token operator">=</span> <span class="token number">10</span></pre></td></tr><tr><td data-num="206"></td><td><pre> <span class="token keyword">let</span> y <span class="token operator">=</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>high<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="207"></td><td><pre> <span class="token keyword">for</span> <span class="token punctuation">(</span><span class="token keyword">let</span> i <span class="token operator">=</span> <span class="token number">2</span><span class="token punctuation">;</span> i <span class="token operator"><</span> offset <span class="token operator">-</span> <span class="token number">1</span><span class="token punctuation">;</span> i <span class="token operator">+=</span> <span class="token number">2</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="208"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">fillText</span><span class="token punctuation">(</span><span class="token string">'.'</span><span class="token punctuation">,</span> x<span class="token punctuation">,</span> y <span class="token operator">-</span> i<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="209"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="210"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">fillText</span><span class="token punctuation">(</span>text<span class="token punctuation">,</span> x<span class="token punctuation">,</span> y <span class="token operator">-</span> offset<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="211"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="212"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>data<span class="token punctuation">.</span>low <span class="token operator">!==</span> <span class="token keyword">undefined</span> <span class="token operator">&&</span> data<span class="token punctuation">.</span>lowOrigin <span class="token operator">===</span> <span class="token boolean">true</span><span class="token punctuation">)</span> <span class="token punctuation">{</span> <span class="token comment">// 画低价</span></pre></td></tr><tr><td data-num="213"></td><td><pre> <span class="token keyword">let</span> text <span class="token operator">=</span> Number<span class="token punctuation">.</span><span class="token function">parseFloat</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>low<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">toFixed</span><span class="token punctuation">(</span><span class="token number">2</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="214"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> <span class="token string">'#fff'</span></pre></td></tr><tr><td data-num="215"></td><td><pre> <span class="token keyword">if</span> <span class="token punctuation">(</span>styles<span class="token punctuation">.</span>line <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors <span class="token operator">&&</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="216"></td><td><pre> ctx<span class="token punctuation">.</span>fillStyle <span class="token operator">=</span> styles<span class="token punctuation">.</span>line<span class="token punctuation">.</span>colors<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span></pre></td></tr><tr><td data-num="217"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="218"></td><td><pre> <span class="token keyword">let</span> offset <span class="token operator">=</span> <span class="token number">15</span></pre></td></tr><tr><td data-num="219"></td><td><pre> <span class="token keyword">let</span> y <span class="token operator">=</span> yAxis<span class="token punctuation">.</span><span class="token function">convertToPixel</span><span class="token punctuation">(</span>data<span class="token punctuation">.</span>low<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="220"></td><td><pre> <span class="token keyword">for</span> <span class="token punctuation">(</span><span class="token keyword">let</span> i <span class="token operator">=</span> <span class="token number">2</span><span class="token punctuation">;</span> i <span class="token operator"><</span> offset <span class="token operator">-</span> <span class="token number">5</span><span class="token punctuation">;</span> i <span class="token operator">+=</span> <span class="token number">2</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></pre></td></tr><tr><td data-num="221"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">fillText</span><span class="token punctuation">(</span><span class="token string">'.'</span><span class="token punctuation">,</span> x<span class="token punctuation">,</span> y <span class="token operator">+</span> i<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="222"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="223"></td><td><pre> ctx<span class="token punctuation">.</span><span class="token function">fillText</span><span class="token punctuation">(</span>text<span class="token punctuation">,</span> x<span class="token punctuation">,</span> y <span class="token operator">+</span> offset<span class="token punctuation">)</span></pre></td></tr><tr><td data-num="224"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="225"></td><td><pre> x <span class="token operator">+=</span> viewport<span class="token punctuation">.</span>dataSpace</pre></td></tr><tr><td data-num="226"></td><td><pre> <span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr><tr><td data-num="227"></td><td><pre> <span class="token punctuation">}</span></pre></td></tr><tr><td data-num="228"></td><td><pre><span class="token punctuation">}</span><span class="token punctuation">)</span></pre></td></tr></table></figure><div class="tags"><a href="/tags/KLineChart/" rel="tag"><i class="ic i-tag"></i> KLineChart</a> <a href="/tags/K%E7%BA%BF/" rel="tag"><i class="ic i-tag"></i> K线</a> <a href="/tags/%E8%87%AA%E5%AE%9A%E4%B9%89%E6%8C%87%E6%A0%87/" rel="tag"><i class="ic i-tag"></i> 自定义指标</a></div></div><footer><div class="meta"><span class="item"><span class="icon"><i class="ic i-calendar-check"></i> </span><span class="text">更新于</span> <time title="修改时间:2023-04-22 21:41:26" itemprop="dateModified" datetime="2023-04-22T21:41:26+08:00">2023-04-22</time> </span><span id="2023/01/31/KLineChart画波段高低价图/" class="item leancloud_visitors" data-flag-title="KLineChart 画波段高低价图" title="阅读次数"><span class="icon"><i class="ic i-eye"></i> </span><span class="text">阅读次数</span> <span class="leancloud-visitors-count"></span> <span class="text">次</span></span></div><div class="reward"><button><i class="ic i-heartbeat"></i> 赞赏</button><p>请我喝[茶]~( ̄▽ ̄)~*</p><div id="qr"><div><img data-src="/images/wechatpay.png" alt="Hito Li 微信支付"><p>微信支付</p></div><div><img data-src="/images/alipay.png" alt="Hito Li 支付宝"><p>支付宝</p></div></div></div><div id="copyright"><ul><li class="author"><strong>本文作者: </strong>Hito Li <i class="ic i-at"><em>@</em></i>涛声依旧</li><li class="link"><strong>本文链接:</strong> <a href="https://hitoli.com/2023/01/31/KLineChart%E7%94%BB%E6%B3%A2%E6%AE%B5%E9%AB%98%E4%BD%8E%E4%BB%B7%E5%9B%BE/" title="KLineChart 画波段高低价图">https://hitoli.com/2023/01/31/KLineChart画波段高低价图/</a></li><li class="license"><strong>版权声明: </strong>本站所有文章除特别声明外,均采用 <span class="exturl" data-url="aHR0cHM6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL2xpY2Vuc2VzL2J5LW5jLXNhLzQuMC9kZWVkLnpo"><i class="ic i-creative-commons"><em>(CC)</em></i>BY-NC-SA</span> 许可协议。转载请注明出处!</li></ul></div></footer></article></div><div class="post-nav"><div class="item left"><a href="/2023/01/10/Vue%E6%A0%B9%E6%8D%AE%E8%B7%AF%E7%94%B1%E4%BC%A0%E5%8F%82%E4%BF%AE%E6%94%B9%E9%A1%B5%E9%9D%A2%E6%95%B0%E6%8D%AE/" itemprop="url" rel="prev" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giclj61ylzj20zk0m8b29.jpg" title="Vue根据路由传参修改页面数据"><span class="type">上一篇</span> <span class="category"><i class="ic i-flag"></i> Vue</span><h3>Vue根据路由传参修改页面数据</h3></a></div><div class="item right"><a href="/2023/02/18/%E4%BF%AE%E6%94%B9IntellIJ-IDE%E8%83%8C%E6%99%AF%E8%89%B2%E5%92%8C%E5%AD%97%E4%BD%93%E5%A4%A7%E5%B0%8F/" itemprop="url" rel="next" data-background-image="https://nas.hitoli.com:18014/images/2022/10/29/6833939bly1giclfb3vzhj20zk0m8wny.jpg" title="修改IntellIJ IDE背景色和字体大小"><span class="type">下一篇</span> <span class="category"><i class="ic i-flag"></i> IDE</span><h3>修改IntellIJ IDE背景色和字体大小</h3></a></div></div><div class="wrap" id="comments"></div></div><div id="sidebar"><div class="inner"><div class="panels"><div class="inner"><div class="contents panel pjax" data-title="文章目录"><ol class="toc"><li class="toc-item toc-level-4"><a class="toc-link" href="#%E5%BC%95%E8%A8%80"><span class="toc-number">1.</span> <span class="toc-text">引言</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#%E6%A8%A1%E7%89%88%E4%BB%A3%E7%A0%81"><span class="toc-number">2.</span> <span class="toc-text">模版代码</span></a></li></ol></div><div class="related panel pjax" data-title="系列文章"><ul><li><a href="/2022/11/24/KLineChart%E5%AE%9E%E7%8E%B0%E4%B8%80%E5%B9%85%E5%9B%BE%E4%B8%8A%E7%94%BB%E5%A4%9A%E4%B8%AA%E8%9C%A1%E7%83%9BK%E7%BA%BF/" rel="bookmark" title="KLineChart实现一幅图上画多个蜡烛K线">KLineChart实现一幅图上画多个蜡烛K线</a></li><li><a href="/2022/12/02/KLineChart%E5%AE%9E%E7%8E%B0%E8%87%AA%E5%AE%9A%E4%B9%89%E6%8C%87%E6%A0%87%E7%94%BB%E5%9B%BE/" rel="bookmark" title="KLineChart实现自定义指标画图">KLineChart实现自定义指标画图</a></li><li class="active"><a href="/2023/01/31/KLineChart%E7%94%BB%E6%B3%A2%E6%AE%B5%E9%AB%98%E4%BD%8E%E4%BB%B7%E5%9B%BE/" rel="bookmark" title="KLineChart画波段高低价图">KLineChart画波段高低价图</a></li></ul></div><div class="overview panel" data-title="站点概览"><div class="author" itemprop="author" itemscope itemtype="http://schema.org/Person"><img class="image" itemprop="image" alt="Hito Li" data-src="/images/avatar.jpg"><p class="name" itemprop="name">Hito Li</p><div class="description" itemprop="description">天生我材必有用</div></div><nav class="state"><div class="item posts"><a href="/archives/"><span class="count">46</span> <span class="name">文章</span></a></div><div class="item categories"><a href="/categories/"><span class="count">20</span> <span class="name">分类</span></a></div><div class="item tags"><a href="/tags/"><span class="count">72</span> <span class="name">标签</span></a></div></nav><div class="social"><span class="exturl item weibo" data-url="aHR0cHM6Ly93ZWliby5jb20vdS8xMDYxNDYwNzQ1" title="https://weibo.com/u/1061460745"><i class="ic i-weibo"></i></span> <span class="exturl item douban" data-url="aHR0cHM6Ly93d3cuZG91YmFuLmNvbS9wZW9wbGUvMjU5Mzc2NTY0" title="https://www.douban.com/people/259376564"><i class="ic i-douban"></i></span> <span class="exturl item music" data-url="aHR0cHM6Ly9tdXNpYy4xNjMuY29tLyMvdXNlci9ob21lP2lkPTEwNTQ2NzQ2Mw==" title="https://music.163.com/#/user/home?id=105467463"><i class="ic i-cloud-music"></i></span> <a href="/about/me" title="about/me" class="item about"><i class="ic i-address-card"></i></a></div><ul class="menu"><li class="item"><a href="/" rel="section"><i class="ic i-home"></i>首页</a></li><li class="item"><a href="/about/me" rel="section"><i class="ic i-user"></i>关于</a></li><li class="item dropdown"><a href="javascript:void(0);"><i class="ic i-feather"></i>文章</a><ul class="submenu"><li class="item"><a href="/archives/" rel="section"><i class="ic i-list-alt"></i>归档</a></li><li class="item"><a href="/categories/" rel="section"><i class="ic i-th"></i>分类</a></li><li class="item"><a href="/tags/" rel="section"><i class="ic i-tags"></i>标签</a></li></ul></li><li class="item"><span class="exturl" data-url="aHR0cHM6Ly93d3cuZm9yZXZlcmJsb2cuY24vZ28uaHRtbA=="><i class="ic i-paper-plane"></i>虫洞</span></li></ul></div></div></div><ul id="quick"><li class="prev pjax"><a href="/2023/01/10/Vue%E6%A0%B9%E6%8D%AE%E8%B7%AF%E7%94%B1%E4%BC%A0%E5%8F%82%E4%BF%AE%E6%94%B9%E9%A1%B5%E9%9D%A2%E6%95%B0%E6%8D%AE/" rel="prev" title="上一篇"><i class="ic i-chevron-left"></i></a></li><li class="up"><i class="ic i-arrow-up"></i></li><li class="down"><i class="ic i-arrow-down"></i></li><li class="next pjax"><a href="/2023/02/18/%E4%BF%AE%E6%94%B9IntellIJ-IDE%E8%83%8C%E6%99%AF%E8%89%B2%E5%92%8C%E5%AD%97%E4%BD%93%E5%A4%A7%E5%B0%8F/" rel="next" title="下一篇"><i class="ic i-chevron-right"></i></a></li><li class="percent"></li></ul></div></div><div class="dimmer"></div></div></main><footer id="footer"><div class="inner"><div class="widgets"><div class="rpost pjax"><h2>随机文章</h2><ul><li class="item"><div class="breadcrumb"><a href="/categories/Linux/" title="分类于 Linux">Linux</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/%E6%9C%8D%E5%8A%A1/" title="分类于 服务">服务</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/%E6%9C%8D%E5%8A%A1/Nginx/" title="分类于 Nginx">Nginx</a></div><span><a href="/2022/11/30/Nginx%E5%8A%A8%E6%80%81%E8%A7%A3%E6%9E%90%E5%9F%9F%E5%90%8D%E6%96%B9%E6%A1%88/" title="Nginx动态解析域名方案">Nginx动态解析域名方案</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/%E5%B7%A5%E4%BD%9C/" title="分类于 工作">工作</a> <i class="ic i-angle-right"></i> <a href="/categories/%E5%B7%A5%E4%BD%9C/%E8%A7%A3%E5%86%B3%E9%97%AE%E9%A2%98/" title="分类于 解决问题">解决问题</a></div><span><a href="/2023/05/25/MySQL%E4%B8%AD%E7%9A%84any-value-%E5%87%BD%E6%95%B0/" title="MySQL中的any_value()函数">MySQL中的any_value()函数</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/%E7%94%9F%E6%B4%BB/" title="分类于 生活">生活</a> <i class="ic i-angle-right"></i> <a href="/categories/%E7%94%9F%E6%B4%BB/%E5%BF%83%E6%83%85/" title="分类于 心情">心情</a></div><span><a href="/2022/09/28/%E6%B7%B1%E6%B7%B1%E7%9A%84%E6%8C%AB%E8%B4%A5%E5%92%8C%E6%97%A0%E5%8A%A9%E6%84%9F/" title="深深的挫败和无助感">深深的挫败和无助感</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/Linux/" title="分类于 Linux">Linux</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/%E6%9C%8D%E5%8A%A1/" title="分类于 服务">服务</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/%E6%9C%8D%E5%8A%A1/Nginx/" title="分类于 Nginx">Nginx</a></div><span><a href="/2022/11/30/%E5%B0%86nginx%E6%9B%BF%E6%8D%A2%E4%B8%BAtengine/" title="将nginx替换为tengine">将nginx替换为tengine</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/Linux/" title="分类于 Linux">Linux</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/%E6%9C%8D%E5%8A%A1/" title="分类于 服务">服务</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/%E6%9C%8D%E5%8A%A1/Nginx/" title="分类于 Nginx">Nginx</a></div><span><a href="/2022/11/30/Nginx%E9%85%8D%E7%BD%AEstream%E8%B8%A9%E5%9D%91/" title="Nginx配置stream踩坑">Nginx配置stream踩坑</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/Linux/" title="分类于 Linux">Linux</a> <i class="ic i-angle-right"></i> <a href="/categories/Linux/Shell/" title="分类于 Shell">Shell</a></div><span><a href="/2022/11/02/2-dev-null%E5%92%8C-dev-null-2-1%E5%92%8C2-1-dev-null%E7%9A%84%E5%8C%BA%E5%88%AB/" title="2>/dev/null和>/dev/null 2>&1和2>&1>/dev/null的区别">2>/dev/null和>/dev/null 2>&1和2>&1>/dev/null的区别</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/%E6%9E%81%E7%A9%BA%E9%97%B4/" title="分类于 极空间">极空间</a> <i class="ic i-angle-right"></i> <a href="/categories/%E6%9E%81%E7%A9%BA%E9%97%B4/Docker/" title="分类于 Docker">Docker</a></div><span><a href="/2022/10/21/%E6%9E%81%E7%A9%BA%E9%97%B4Docker%E7%89%88mariadb%E5%AE%89%E8%A3%85%E4%B8%8E%E9%85%8D%E7%BD%AE/" title="极空间Docker版mariadb安装与配置">极空间Docker版mariadb安装与配置</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/%E5%B7%A5%E4%BD%9C/" title="分类于 工作">工作</a> <i class="ic i-angle-right"></i> <a href="/categories/%E5%B7%A5%E4%BD%9C/%E8%A7%A3%E5%86%B3%E9%97%AE%E9%A2%98/" title="分类于 解决问题">解决问题</a></div><span><a href="/2023/05/30/http%E8%AF%B7%E6%B1%82%E4%B9%8BrestTemplate%E9%85%8D%E7%BD%AE%E8%B6%85%E6%97%B6%E6%97%B6%E9%97%B4/" title="http请求之restTemplate配置超时时间">http请求之restTemplate配置超时时间</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/%E5%B7%A5%E4%BD%9C/" title="分类于 工作">工作</a> <i class="ic i-angle-right"></i> <a href="/categories/%E5%B7%A5%E4%BD%9C/KLineChart/" title="分类于 KLineChart">KLineChart</a></div><span><a href="/2022/11/24/KLineChart%E5%AE%9E%E7%8E%B0%E4%B8%80%E5%B9%85%E5%9B%BE%E4%B8%8A%E7%94%BB%E5%A4%9A%E4%B8%AA%E8%9C%A1%E7%83%9BK%E7%BA%BF/" title="KLineChart实现一幅图上画多个蜡烛K线">KLineChart实现一幅图上画多个蜡烛K线</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/%E7%94%9F%E6%B4%BB/" title="分类于 生活">生活</a> <i class="ic i-angle-right"></i> <a href="/categories/%E7%94%9F%E6%B4%BB/%E6%8A%80%E6%9C%AF%E5%88%86%E4%BA%AB/" title="分类于 技术分享">技术分享</a></div><span><a href="/2023/04/16/%E5%91%BD%E4%BB%A4%E5%A4%A7%E6%9D%82%E7%83%A9/" title="命令大杂烩">命令大杂烩</a></span></li></ul></div><div><h2>最新评论</h2><ul class="leancloud-recent-comment"></ul></div></div><div class="status"><div class="copyright">© 2010 – <span itemprop="copyrightYear">2023</span> <span class="with-love"><i class="ic i-sakura rotate"></i> </span><span class="author" itemprop="copyrightHolder">Hito Li @ ☆∵∴Hito∴∵★</span></div><div class="count"><span class="post-meta-item-icon"><i class="ic i-chart-area"></i> </span><span title="站点总字数">89k 字</span> <span class="post-meta-divider">|</span> <span class="post-meta-item-icon"><i class="ic i-coffee"></i> </span><span title="站点阅读时长">1:21</span></div><div class="powered-by">基于 <span class="exturl" data-url="aHR0cHM6Ly9oZXhvLmlv">Hexo</span> & Theme.<span class="exturl" data-url="aHR0cHM6Ly9naXRodWIuY29tL2FtZWhpbWUvaGV4by10aGVtZS1zaG9rYQ==">Shoka</span></div></div></div></footer></div><script data-config type="text/javascript">var LOCAL={path:"2023/01/31/KLineChart画波段高低价图/",favicon:{show:"(●´3‘●)哎呀呀",hide:"(´Д`)真糟糕!"},search:{placeholder:"文章搜索",empty:"关于 「 ${query} 」,什么也没搜到",stats:"${time} ms 内找到 ${hits} 条结果"},valine:!0,fancybox:!0,copyright:'复制成功,转载请遵守 <i class="ic i-creative-commons"></i>BY-NC-SA 协议。',ignores:[function(e){return e.includes("#")},function(e){return new RegExp(LOCAL.path+"$").test(e)}]}</script><script src="https://cdn.polyfill.io/v2/polyfill.js"></script><script src="//cdn.jsdelivr.net/combine/npm/pace-js@1.0.2/pace.min.js,npm/pjax@0.2.8/pjax.min.js,npm/whatwg-fetch@3.4.0/dist/fetch.umd.min.js,npm/animejs@3.2.0/lib/anime.min.js,npm/algoliasearch@4/dist/algoliasearch-lite.umd.js,npm/instantsearch.js@4/dist/instantsearch.production.min.js,npm/lozad@1/dist/lozad.min.js,npm/quicklink@2/dist/quicklink.umd.js"></script><script src="/js/app.js?v=0.0.0"></script></body></html> |