一个开源的 HTML5 期货行情交易终端。
在线演示地址 https://shinnytech.github.io/shinny-futures-h5/index.html ,使用手机扫一扫,用手机浏览器打开效果更好。
- 期货合约行情报价。
- K线图,Tick图,盘口报价。
- 登录期货交易账户。
- 查看账户资金。
- 下单、撤单。
- 查看账户持仓记录,委托单记录。
- 按照手数平仓。
- 银期转账及转账记录。
- 可配置界面。
git clone https://github.com/shinnytech/shinny-futures-h5
可以选择任意一种熟悉的开发环境来运行。
-
NodeJs 环境下
-
安装 nodejs。
-
安装 http-server
npm install -g http-server
。 -
项目目录下运行
http-server -a 0.0.0.0 -p 8888
。 -
浏览器打开
http://127.0.0.1:8888/
。
-
-
Python 环境下
-
安装 python。
-
查看 python 版本
python -V
。 -
项目目录下运行:
python -m http.server
(python版本 3.X)python -m SimpleHTTPServer
(python版本 2.X) -
浏览器打开
http://127.0.0.1:8000/
。
-
-
Chrome 浏览器插件
-
安装 Chrome 浏览器。
-
在 Chrome 浏览器安装 web-server-for-chrome 插件。
-
在 web-server-for-chrome 插件中选择项目文件夹,输入端口号,即可在浏览器访问。
-
修改 zqjs/configuration.js
文件可以对项目进行配置。
var SETTING = {
sim_server_url: 'wss://openmd.shinnytech.com/t/md/front/mobile', // 行情接口
tr_server_url: 'wss://opentd.shinnytech.com/trade/user0', // 交易接口
default_bid: '快期模拟', // 默认期货公司
reconnect_interval: 2000, // 重连时间间隔 ms
reconnect_max_times: 5, // 最大尝试重连次数
};
// CONST 对象用来保存界面显示相关参数,不要删除这个对象
var CONST = { ... }
行情报价列表每个合约分两行显示, 通过以下设置可以配置需要显示的字段,例如:
var CONST = {
// ......
// 第一行显示的字段
inslist_cols_odd: ['last_price', 'highest', 'volume', 'pre_close'],
// 第二行显示的字段
inslist_cols_even: ['change', 'lowest', 'open_interest', 'open'],
// 所有可选的字段,及对应列首显示名称
inslist_cols_name: {
"volume_multiple": "合约乘数",
"price_tick": "价格单位",
"ask_price1": "卖价",
"ask_volume1": "卖量",
"bid_price1": "买价",
"bid_volume1": "买量",
"last_price": "最新价",
"highest": "最高价",
"lowest": "最低价",
"amount": "成交额",
"volume": "成交量",
"open_interest": "持仓量",
"pre_open_interest": "昨持仓",
"pre_close": "昨收",
"open": "今开",
"close": "收盘",
"lower_limit": "跌停",
"upper_limit": "涨停",
"average": "均价",
"pre_settlement": "昨结",
"settlement": "结算价",
"change": "涨跌",
"change_percent": "涨跌幅"
},
// ......
}
var CONST = {
// ......
chart_color: {
'background': "#111", // K线图背景色
'down': '#00FFFF', // 下跌柱子颜色
'up': 'red', // 上涨柱子颜色
},
// ......
}
/**
* SymbolFilter 过滤合约列表
* symbol 合约名称
* symbolObj 合约描述对象
*/
function SymbolFilter (symbol, symbolObj) {
// 需要显示的合约返回 true;不显示的合约返回 false
// 示例: 只显示上期所合约
if (symbol.exchange_id('SHFE')) return true;
return false;
}
symbol 表示某一个的合约,格式为 交易所代码.合约代码
。
交易所代码如下:
交易所 | 代码 |
---|---|
**金融期货交易所 | CFFEX |
上海期货交易所 | SHFE |
大连商品交易所 | DCE |
郑州商品交易所 | CZCE |
能源交易所(原油) | INE |
var CONST = {
// ......
// 不同交易所
inslist_types: [
{id: 'main', name: '主力合约'},
{id: 'custom', name: '自选合约'},
{id: 'SHFE', name: '上期所'},
{id: 'CZCE', name: '郑商所'},
{id: 'INE', name: '上期能源'},
{id: 'DCE', name: '大商所'},
{id: 'CFFEX', name: '中金所'}
],
// 默认首选的交易所
default_inslist_type: {id: 'main', name: '主力合约'},
// ......
}
合约列表可以按照不同交易所分类显示,可以修改数组以显示不同的交易所。
- 支持鼠标操作 K 线图,拖动、缩放
- 确认登录逻辑
- 按品种快速定位合约列表
- 可以按照手数平仓
- 添加可配置选项
- 部分手机列表页滑动不流畅,显示重叠
- 键盘首次打开删除键无效
- 市价委托单价格显示0
- Ios 锁屏退出后,重连服务器,没有登录