Skip to content

Latest commit

 

History

History
265 lines (206 loc) · 7.1 KB

README.md

File metadata and controls

265 lines (206 loc) · 7.1 KB

Dick.js

👽 dick [dɪk] ...

简介

Dickjs 是一套遵循ES6语法规范的小程序前端终极地狱解决方案。现如今市面上小程序框架的多种多样。dickjs是针对原生小程序中快速开发的解决方案,使用dickjs可以方便快捷开发小程序在实现逻辑上更加迅速。

Dick.js内容目录

TODO

  • √ Websocket
  • □ Dick MIN JS
  • □ Dick CLI

逻辑层

Dickjs语法规则灵感源自于Vue,它采用与Vue一致的开发思想,组件生命周期与Vue保持一致,同时在书写体验上也尽量与Vue类似,让代码具有更丰富的表现力。

代码示例

var vm = Page.VM({
  // 数据
  data: {
    model: 'dick.js'
  },
  // 计算属性
  computed: {
    upper: function(){
    }
  },
  // 方法
  methods: {
    change: function(name){
    }
  },
  // onLoad
  mounted: function(){
    vm.change()
  }
})

this

js内成员函数中的this指向data,并且computedmethods的成员也可以通过this进行访问、取值。

小程序内无须setData

直接通过this进行修改数据,页面会自动更新视图

var vm = Page.VM()返回this,方便在异步函数内直接使用vm

mounted

mounted函数映射为小程序内onLoad函数

控制台调试

在开发工具控制台可以通过Page.vm访问当前页面的vm,方便调试

Page.vm.model = 'dick.js'

wxml传参给js

原生小程序事件处理函数不能直接传参,有且只有事件对象作为参数, 但要传递参数时只能能过data-x="{{'value'}}",然后event.target.dataset的方式获取,为了方便将dataset作为第二个参数传给js处理函数。另外,实际上大多数情况我们并不会用到event,所以如果存在data-e时,将代替event直接作为处理函数的参数

(dataset.e||event, dataset)

双向绑定

小程序没有直接进行双向绑定,通语法糖实现

view->model: 通过data-model实现视图层到逻辑层的数据修改

model->view: 逻辑层到视图层的数据传递为原生小程序的value="{{model}}"

<input bindinput="$model" data-model="model" value="{{model}}></input>

data-model支持复杂的层级,如:data-model="form.list[0].name"

使用方法

  1. 在入口文件app.js中引入dick.js
require('./dickVM.js')
  1. 在页面js中直接使用
Page.VM(e){}

使用说明

引入dickZXY.js

import {
  InsertRecord,
  Select,
  ConditionSelect
} from './dick/dickZXY'

js中使用

let insertRecord = new InsertRecord(config.hualao_tableID, record)

实例化dick类 根据构建参数实现api操作

✅查询列表

let LIST = new SELECT(CONFIG.ID, 10, 0, `-created_at`)
LIST.select().then(res => this.LISTDATA = res)

构建参数

  1. 表ID
  2. 查询数量limit
  3. 偏移量offset
  4. 排序方式

✅条件查询列表

let LIST = new SELECT(CONFIG.ID,CONDITION, 10, 0, `-created_at`)
LIST.select().then(res => this.LISTDATA = res)

构建参数

  1. 表ID
  2. 查询条件
  3. 查询数量limit
  4. 偏移量offset
  5. 排序方式

✅查询单值

let ITEM = new SelectTable(CONFIG.ID, RECORDID, null, null, ``)
selectNews.select().then(res => this.ITEM = res)

构建参数

  1. 表ID
  2. 记录ID

✅添加记录

let RECORD = {
    id : id,
    name : name,
}
let RESULT = new InsertRecord(CONFIG.ID, RECORD)
insertRecord.insert().then(res => {...})

构建参数

  1. 表ID
  2. 记录

使用方法

在需要websocket文件的*.js中引入dickWebSocket.js

import { Websocket } from './dick/dickWebSocket'

✅加载WebSocket

Join the ChatRoom

let websocket = new Websocket('URL');

✅接收Socket消息

 wx.onSocketMessage(function (res) {
   // TODO
 }

✅发送Socket消息

 wx.sendSocketMessage({
    // TODO
 })
var clients = [];
var uuid = require('node-uuid');
var WebSocketServer = require('ws').Server,
wss = new WebSocketServer({ port: 8080 });
wss.on('connection', function (ws) {
  var client_uuid = uuid.v4();
  var nickname = client_uuid.substr(0, 8);
  clients.push({ "id": client_uuid, "ws": ws, "nickname": nickname });
  console.log('client [%s] connected', client_uuid);
  ws.on('message', function (message) {
    for (var i = 0; i < clients.length; i++) {
      var clientSocket = clients[i].ws;
      console.log('client [%s]:%s', clients[i].id, message);
      clientSocket.send(JSON.stringify({
        "id": client_uuid,
        "message": message
      }));
    }
  });

  ws.on('close', function () {
    for (var i = 0; i < clients.length; i++) {
      if (clients[i].id == client_uuid) {
        console.log('client [%s] disconnected', client_uuid);
        clients.splice(i, 1);
      }
    }
  })
})

License

MIT License

Copyright (c) 2018 lihongzheng

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.