基于jQuery的500行小型响应式框架jQvm

广告位招租
扫码页面底部二维码联系

因为做一个用于生成水印的小型工具,使用到本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。electron作为壳,在选ui框架的时【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net候,当然是首先想到vue,但是经过一会儿【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。使用后,发现vue机制在electron【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。下面无法直接使用脚本引入方式,有些遗憾,未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net于是打算直接使用jquery。但是写了一【版权所有,侵权必究】【转载请注明来源】会儿之后,又觉得别扭,写react和vu本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】e太久,通过修改状态来触发界面重绘,这种【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。方式实在太顺手了,现在去写jquery的【未经授权禁止转载】【作者:唐霜】代码,实在有些回不去的感觉。

【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】

于是乎,我自己写了一个基于jquery的本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net响应式插件,也可以把它当作是一个小框架。

【关注微信公众号:wwwtangshuangnet】【访问 www.tangshuang.net 获取更多精彩内容】【原创不易,请尊重版权】原创内容,盗版必究。【转载请注明来源】

github.com/tangshuan未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。g/jqvm

本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】

具体使用方法如下:【未经授权禁止转载】

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】
<script src="https://unpkg.com/jquery/dist/jquery.min.js"></script>
<script src="https://unpkg.com/jqvm/dist/jqvm.min.js"></script>

<template id="app">
  <span>{{name}}</span>
  <span>{{age}}</span>
  <button>grow</button>
</template>

<script>
$('#app')
  .vm({
    name: 'tomy',
    age: 12,
  })
  .on('click', 'button', state => {
    state.age ++
  })
  .mount()
</script> 

以上就是最简单的用法。模板定义和vue差原创内容,盗版必究。【原创内容,转载请注明出处】不多,但是有个大的区别,vue直接在模板【版权所有,侵权必究】原创内容,盗版必究。里面绑定事件,但是在jqvm中通过传统的本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。jquery的on绑定事件。

【原创内容,转载请注明出处】【作者:唐霜】转载请注明出处:www.tangshuang.net

它有一些内置的directive(指令)【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】,最常用的应该是jq-if了。

原创内容,盗版必究。转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。
<template>
  <div jq-if="isTouched">xxx</div>
</template> 

还可以在mount 之前注册一些comp本文作者:唐霜,转载请注明出处。【转载请注明来源】onent和directive。

本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】【未经授权禁止转载】【作者:唐霜】【转载请注明来源】
const { component, directive } = $.vm

component('icon', function(el, attrs) {
  const { type } = attrs
  return `<i class="icon icon-${type}"></i>`
})

directive('jq-link', function(el, attrs) {
  const link = attrs['jq-link']
  const to = this.parse(link) // this.parse 是一个内置服务,用来将字符串解析成 state 上的对应值
  el.attr('href', to)
})

注册好之后,在模板里面使用。【访问 www.tangshuang.net 获取更多精彩内容】

【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。
<template>
  <icon type="search"></icon>
  <a jq-link="xxx">jump</a>
</template>

再来说说设计理念,我的想法,就是“简单”【本文首发于唐霜的博客】【版权所有,侵权必究】。使用简单,也别整特别多概念,虽然我前面本文版权归作者所有,未经授权不得转载。【作者:唐霜】提到vm, state之类的,一看基本上【未经授权禁止转载】【作者:唐霜】都能明白咋回事,拿过来就撸,别想那么多。本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】不过还是需要再解释一下on那里怎么绑定事【作者:唐霜】原创内容,盗版必究。件,第三个参数是一个函数,这个函数接收s【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】tate,这个state被修改就会重新渲本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】染,这个函数返回一个函数,返回的这个函数本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】就是正常情况下我们用 jquery.fn【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】.on绑定的时候传入的那个函数。

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。
$('#app')
  .vm({ ... })
  .on('click', 'button', state => function(e) {
    const color = $(this).css('color')
    state.color = color
    // ...
  })

这个小框架打包压缩之后,总体体积不到50【本文受版权保护】著作权归作者所有,禁止商业用途转载。k,可以说麻雀虽小,五脏俱全。也没有啥特【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。别新潮的东西,在一些需要1分钟内开始界面【本文受版权保护】著作权归作者所有,禁止商业用途转载。编程的场景,再适合不过了。

【访问 www.tangshuang.net 获取更多精彩内容】【原创不易,请尊重版权】【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。【本文受版权保护】

github.com/tangshuan【版权所有】唐霜 www.tangshuang.net【转载请注明来源】g/jqvm

【关注微信公众号:wwwtangshuangnet】【本文受版权保护】【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net

如果你觉得这个项目有点意思,给个star【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。吧。

原创内容,盗版必究。转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】
已有1条评论
  1. 2023-11-12 02:31

    牛逼!