mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
254 lines (215 loc) • 27.9 kB
HTML
<html>
<head>
<title>hover.html</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link rel="stylesheet" media="all" href="../../../doc-style.css" />
<script src="../../../doc-filelist.js"></script>
<script>
var relativeDir = "../../../", thisFile = "Users/knut/Documents/source/mermaid/bower_components/dagre-d3/demo/hover.html", defaultSidebar = true;
</script>
<script src="../../../doc-script.js"></script>
<script src="../../../mermaid.js"></script>
<link rel="stylesheet" href="../../../mermaid.css" />
</head>
<body>
<div id="sidebar_wrapper">
<div id="sidebar_switch">
<span class="tree">Files</span>
<span class="headings">Headings</span>
</div>
<div id="tree"></div>
<div id="headings">
<div class="heading h1">
<a href="#hover.html">hover.html</a>
</div>
</div>
</div>
<div id="sidebar-toggle"></div>
<div id="container"><div class="background highlight"></div>
<table cellpadding="0" cellspacing="0">
<tbody>
<tr>
<td class="docs">
<div class="pilwrap" id="hover.html">
<h1>
<a href="#hover.html" name="hover.html" class="pilcrow">¶</a>hover.html
</h1>
</div>
</td>
<td class="code highlight"></td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-1" id="section-1">¶</a>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="cp"><!doctype html></span>
<span class="nt"><meta</span> <span class="na">charset=</span><span class="s">"utf-8"</span><span class="nt">></span>
<span class="nt"><title></span>Dagre D3 Demo: Tooltip on Hover<span class="nt"></title></span>
<span class="nt"><link</span> <span class="na">rel=</span><span class="s">"stylesheet"</span> <span class="na">href=</span><span class="s">"demo.css"</span><span class="nt">></span>
<span class="nt"><script </span><span class="na">src=</span><span class="s">"http://d3js.org/d3.v3.min.js"</span> <span class="na">charset=</span><span class="s">"utf-8"</span><span class="nt">></script></span>
<span class="nt"><script </span><span class="na">src=</span><span class="s">"../build/dagre-d3.js"</span><span class="nt">></script></span>
<span class="c"><!-- Pull in JQuery dependencies --></span>
<span class="nt"><link</span> <span class="na">rel=</span><span class="s">"stylesheet"</span> <span class="na">href=</span><span class="s">"tipsy.css"</span><span class="nt">></span>
<span class="nt"><script </span><span class="na">src=</span><span class="s">"http://code.jquery.com/jquery-1.9.1.min.js"</span><span class="nt">></script></span>
<span class="nt"><script </span><span class="na">src=</span><span class="s">"tipsy.js"</span><span class="nt">></script></span>
<span class="nt"><h1></span>Dagre D3 Demo: Tooltip on Hover<span class="nt"></h1></span>
<span class="nt"><style </span><span class="na">id=</span><span class="s">"css"</span><span class="nt">></span>
<span class="nt">text</span> <span class="p">{</span>
<span class="k">font-weight</span><span class="o">:</span> <span class="m">300</span><span class="p">;</span>
<span class="k">font-family</span><span class="o">:</span> <span class="s2">"Helvetica Neue"</span><span class="o">,</span> <span class="n">Helvetica</span><span class="o">,</span> <span class="n">Arial</span><span class="o">,</span> <span class="n">sans</span><span class="o">-</span><span class="n">serf</span><span class="p">;</span>
<span class="k">font-size</span><span class="o">:</span> <span class="m">14px</span><span class="p">;</span>
<span class="p">}</span>
<span class="nc">.node</span> <span class="nt">rect</span> <span class="p">{</span>
<span class="n">stroke</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span>
<span class="n">fill</span><span class="o">:</span> <span class="m">#fff</span><span class="p">;</span>
<span class="p">}</span>
<span class="nc">.edgePath</span> <span class="nt">path</span> <span class="p">{</span>
<span class="n">stroke</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span>
<span class="n">fill</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span>
<span class="n">stroke</span><span class="o">-</span><span class="k">width</span><span class="o">:</span> <span class="m">1.5px</span><span class="p">;</span>
<span class="p">}</span>
<span class="nc">.node</span> <span class="nt">text</span> <span class="p">{</span>
<span class="k">pointer</span><span class="o">-</span><span class="n">events</span><span class="o">:</span> <span class="k">none</span><span class="p">;</span>
<span class="p">}</span>
<span class="c">/* This styles the title of the tooltip */</span>
<span class="nc">.tipsy</span> <span class="nc">.name</span> <span class="p">{</span>
<span class="k">font-size</span><span class="o">:</span> <span class="m">1.5em</span><span class="p">;</span>
<span class="k">font-weight</span><span class="o">:</span> <span class="k">bold</span><span class="p">;</span>
<span class="k">color</span><span class="o">:</span> <span class="m">#60b1fc</span><span class="p">;</span>
<span class="k">margin</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span>
<span class="p">}</span>
<span class="c">/* This styles the body of the tooltip */</span>
<span class="nc">.tipsy</span> <span class="nc">.description</span> <span class="p">{</span>
<span class="k">font-size</span><span class="o">:</span> <span class="m">1.2em</span><span class="p">;</span>
<span class="p">}</span>
<span class="nt"></style></span>
<span class="nt"><svg</span> <span class="na">width=</span><span class="s">960</span> <span class="na">height=</span><span class="s">600</span><span class="nt">></svg></span>
<span class="nt"><section></span>
<span class="nt"><p></span>The TCP state diagram
(<span class="nt"><a</span> <span class="na">href=</span><span class="s">"http://www.rfc-editor.org/rfc/rfc793.txt"</span><span class="nt">></span>source: RFC 793<span class="nt"></a></span>) with
hover support. Uses <span class="nt"><a</span> <span class="na">href=</span><span class="s">"http://bl.ocks.org/ilyabo/1373263"</span><span class="nt">></span>tipsy JS and CSS<span class="nt"></a></span>
for the tooltip.
<span class="nt"></section></span>
<span class="nt"><script </span><span class="na">id=</span><span class="s">"js"</span><span class="nt">></span>
<span class="c1">// Create a new directed graph</span>
<span class="kd">var</span> <span class="nx">g</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">dagreD3</span><span class="p">.</span><span class="nx">graphlib</span><span class="p">.</span><span class="nx">Graph</span><span class="p">().</span><span class="nx">setGraph</span><span class="p">({});</span>
<span class="c1">// States and transitions from RFC 793</span>
<span class="kd">var</span> <span class="nx">states</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">CLOSED</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents no connection state at all."</span><span class="p">,</span>
<span class="nx">style</span><span class="o">:</span> <span class="s2">"fill: #f77"</span>
<span class="p">},</span>
<span class="nx">LISTEN</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a connection request from any "</span> <span class="o">+</span>
<span class="s2">"remote TCP and port."</span>
<span class="p">},</span>
<span class="s2">"SYN SENT"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a matching connection "</span> <span class="o">+</span>
<span class="s2">"request after having sent a connection request."</span>
<span class="p">},</span>
<span class="s2">"SYN RCVD"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a confirming connection "</span> <span class="o">+</span>
<span class="s2">"request acknowledgment after having both received and sent a "</span> <span class="o">+</span>
<span class="s2">"connection request."</span>
<span class="p">},</span>
<span class="nx">ESTAB</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents an open connection, data received "</span> <span class="o">+</span>
<span class="s2">"can be delivered to the user. The normal state for the data "</span> <span class="o">+</span>
<span class="s2">"transfer phase of the connection."</span><span class="p">,</span>
<span class="nx">style</span><span class="o">:</span> <span class="s2">"fill: #7f7"</span>
<span class="p">},</span>
<span class="s2">"FINWAIT-1"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a connection termination "</span> <span class="o">+</span>
<span class="s2">"request from the remote TCP, or an acknowledgment of the "</span> <span class="o">+</span>
<span class="s2">"connection termination request previously sent."</span>
<span class="p">},</span>
<span class="s2">"FINWAIT-2"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a connection termination "</span> <span class="o">+</span>
<span class="s2">"request from the remote TCP."</span>
<span class="p">},</span>
<span class="s2">"CLOSE WAIT"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a connection termination "</span> <span class="o">+</span>
<span class="s2">"request from the local user."</span>
<span class="p">},</span>
<span class="nx">CLOSING</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for a connection termination "</span> <span class="o">+</span>
<span class="s2">"request acknowledgment from the remote TCP."</span>
<span class="p">},</span>
<span class="s2">"LAST-ACK"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for an acknowledgment of the "</span> <span class="o">+</span>
<span class="s2">"connection termination request previously sent to the remote "</span> <span class="o">+</span>
<span class="s2">"TCP (which includes an acknowledgment of its connection "</span> <span class="o">+</span>
<span class="s2">"termination request)."</span>
<span class="p">},</span>
<span class="s2">"TIME WAIT"</span><span class="o">:</span> <span class="p">{</span>
<span class="nx">description</span><span class="o">:</span> <span class="s2">"represents waiting for enough time to pass to be "</span> <span class="o">+</span>
<span class="s2">"sure the remote TCP received the acknowledgment of its "</span> <span class="o">+</span>
<span class="s2">"connection termination request."</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="c1">// Add states to the graph, set labels, and style</span>
<span class="nb">Object</span><span class="p">.</span><span class="nx">keys</span><span class="p">(</span><span class="nx">states</span><span class="p">).</span><span class="nx">forEach</span><span class="p">(</span><span class="kd">function</span><span class="p">(</span><span class="nx">state</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">value</span> <span class="o">=</span> <span class="nx">states</span><span class="p">[</span><span class="nx">state</span><span class="p">];</span>
<span class="nx">value</span><span class="p">.</span><span class="nx">label</span> <span class="o">=</span> <span class="nx">state</span><span class="p">;</span>
<span class="nx">value</span><span class="p">.</span><span class="nx">rx</span> <span class="o">=</span> <span class="nx">value</span><span class="p">.</span><span class="nx">ry</span> <span class="o">=</span> <span class="mi">5</span><span class="p">;</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setNode</span><span class="p">(</span><span class="nx">state</span><span class="p">,</span> <span class="nx">value</span><span class="p">);</span>
<span class="p">});</span>
<span class="c1">// Set up the edges</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"CLOSED"</span><span class="p">,</span> <span class="s2">"LISTEN"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"open"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"LISTEN"</span><span class="p">,</span> <span class="s2">"SYN RCVD"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv SYN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"LISTEN"</span><span class="p">,</span> <span class="s2">"SYN SENT"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"send"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"LISTEN"</span><span class="p">,</span> <span class="s2">"CLOSED"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"close"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"SYN RCVD"</span><span class="p">,</span> <span class="s2">"FINWAIT-1"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"close"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"SYN RCVD"</span><span class="p">,</span> <span class="s2">"ESTAB"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv ACK of SYN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"SYN SENT"</span><span class="p">,</span> <span class="s2">"SYN RCVD"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv SYN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"SYN SENT"</span><span class="p">,</span> <span class="s2">"ESTAB"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv SYN, ACK"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"SYN SENT"</span><span class="p">,</span> <span class="s2">"CLOSED"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"close"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"ESTAB"</span><span class="p">,</span> <span class="s2">"FINWAIT-1"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"close"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"ESTAB"</span><span class="p">,</span> <span class="s2">"CLOSE WAIT"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv FIN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"FINWAIT-1"</span><span class="p">,</span> <span class="s2">"FINWAIT-2"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv ACK of FIN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"FINWAIT-1"</span><span class="p">,</span> <span class="s2">"CLOSING"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv FIN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"CLOSE WAIT"</span><span class="p">,</span> <span class="s2">"LAST-ACK"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"close"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"FINWAIT-2"</span><span class="p">,</span> <span class="s2">"TIME WAIT"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv FIN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"CLOSING"</span><span class="p">,</span> <span class="s2">"TIME WAIT"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv ACK of FIN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"LAST-ACK"</span><span class="p">,</span> <span class="s2">"CLOSED"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"rcv ACK of FIN"</span> <span class="p">});</span>
<span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="s2">"TIME WAIT"</span><span class="p">,</span> <span class="s2">"CLOSED"</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="s2">"timeout=2MSL"</span> <span class="p">});</span>
<span class="c1">// Create the renderer</span>
<span class="kd">var</span> <span class="nx">render</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">dagreD3</span><span class="p">.</span><span class="nx">render</span><span class="p">();</span>
<span class="c1">// Set up an SVG group so that we can translate the final graph.</span>
<span class="kd">var</span> <span class="nx">svg</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">select</span><span class="p">(</span><span class="s2">"svg"</span><span class="p">),</span>
<span class="nx">inner</span> <span class="o">=</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"g"</span><span class="p">);</span>
<span class="c1">// Set up zoom support</span>
<span class="kd">var</span> <span class="nx">zoom</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">behavior</span><span class="p">.</span><span class="nx">zoom</span><span class="p">().</span><span class="nx">on</span><span class="p">(</span><span class="s2">"zoom"</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="nx">inner</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"transform"</span><span class="p">,</span> <span class="s2">"translate("</span> <span class="o">+</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">event</span><span class="p">.</span><span class="nx">translate</span> <span class="o">+</span> <span class="s2">")"</span> <span class="o">+</span>
<span class="s2">"scale("</span> <span class="o">+</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">event</span><span class="p">.</span><span class="nx">scale</span> <span class="o">+</span> <span class="s2">")"</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">svg</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">zoom</span><span class="p">);</span>
<span class="c1">// Simple function to style the tooltip for the given node.</span>
<span class="kd">var</span> <span class="nx">styleTooltip</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">name</span><span class="p">,</span> <span class="nx">description</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="s2">"<p class='name'>"</span> <span class="o">+</span> <span class="nx">name</span> <span class="o">+</span> <span class="s2">"</p><p class='description'>"</span> <span class="o">+</span> <span class="nx">description</span> <span class="o">+</span> <span class="s2">"</p>"</span><span class="p">;</span>
<span class="p">};</span>
<span class="c1">// Run the renderer. This is what draws the final graph.</span>
<span class="nx">render</span><span class="p">(</span><span class="nx">inner</span><span class="p">,</span> <span class="nx">g</span><span class="p">);</span>
<span class="nx">inner</span><span class="p">.</span><span class="nx">selectAll</span><span class="p">(</span><span class="s2">"g.node"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"title"</span><span class="p">,</span> <span class="kd">function</span><span class="p">(</span><span class="nx">v</span><span class="p">)</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">styleTooltip</span><span class="p">(</span><span class="nx">v</span><span class="p">,</span> <span class="nx">g</span><span class="p">.</span><span class="nx">node</span><span class="p">(</span><span class="nx">v</span><span class="p">).</span><span class="nx">description</span><span class="p">)</span> <span class="p">})</span>
<span class="p">.</span><span class="nx">each</span><span class="p">(</span><span class="kd">function</span><span class="p">(</span><span class="nx">v</span><span class="p">)</span> <span class="p">{</span> <span class="nx">$</span><span class="p">(</span><span class="k">this</span><span class="p">).</span><span class="nx">tipsy</span><span class="p">({</span> <span class="nx">gravity</span><span class="o">:</span> <span class="s2">"w"</span><span class="p">,</span> <span class="nx">opacity</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span> <span class="nx">html</span><span class="o">:</span> <span class="kc">true</span> <span class="p">});</span> <span class="p">});</span>
<span class="c1">// Center the graph</span>
<span class="kd">var</span> <span class="nx">initialScale</span> <span class="o">=</span> <span class="mf">0.75</span><span class="p">;</span>
<span class="nx">zoom</span>
<span class="p">.</span><span class="nx">translate</span><span class="p">([(</span><span class="nx">svg</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"width"</span><span class="p">)</span> <span class="o">-</span> <span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">width</span> <span class="o">*</span> <span class="nx">initialScale</span><span class="p">)</span> <span class="o">/</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">20</span><span class="p">])</span>
<span class="p">.</span><span class="nx">scale</span><span class="p">(</span><span class="nx">initialScale</span><span class="p">)</span>
<span class="p">.</span><span class="nx">event</span><span class="p">(</span><span class="nx">svg</span><span class="p">);</span>
<span class="nx">svg</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'height'</span><span class="p">,</span> <span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">height</span> <span class="o">*</span> <span class="nx">initialScale</span> <span class="o">+</span> <span class="mi">40</span><span class="p">);</span>
<span class="nt"></script></span>
<span class="nt"><script </span><span class="na">src=</span><span class="s">"demo.js"</span><span class="nt">></script></span>
</pre></div>
</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>