HBuilderX

HBuilderX

极客开发工具
uni-app

uni-app

开发一次,多端覆盖
uniCloud

uniCloud

云开发平台
HTML5+

HTML5+

增强HTML5的功能体验
MUI

MUI

上万Star的前端框架

判断进入登录页还是首页

登录状态

页面初始化的时候,未登录跳转到登录页的话,会闪一下pages.json里的第一个首页。

而使用首页v-if来切换登录页面模板的话,tabbar又会闪一下。哪怕是在app.vue里写了uni.hideTabbar(),还是会闪。

最终只能在pages.json第一项搞个空白页,然后redirect到登录页了,看起来自然一点。

(我测试的环境是微信小程序,使用的hbuilderX是2.9.8)

继续阅读 »

页面初始化的时候,未登录跳转到登录页的话,会闪一下pages.json里的第一个首页。

而使用首页v-if来切换登录页面模板的话,tabbar又会闪一下。哪怕是在app.vue里写了uni.hideTabbar(),还是会闪。

最终只能在pages.json第一项搞个空白页,然后redirect到登录页了,看起来自然一点。

(我测试的环境是微信小程序,使用的hbuilderX是2.9.8)

收起阅读 »

vue nvue canvas video的吐槽

商品详情有个canvas画海报的功能,一开始没什么的
一天商品详情被要求支持短视频video,也没啥的
video在vue swiper中不能轮播,嗯开始有问题了
官方的建议是使用nvue
切换了一天,vue swiper video很完美
开心。。。。。
下班。。。。。
。。。。。。。
半路
测试说APP无法生成海报
卧槽,nvue不支持canvas
so,我现在又在电脑面前找解决方案
兄弟们
九九孩子

官方的NvueCanvasDemo不是我想要的

看来只能麻烦后台了

继续阅读 »

商品详情有个canvas画海报的功能,一开始没什么的
一天商品详情被要求支持短视频video,也没啥的
video在vue swiper中不能轮播,嗯开始有问题了
官方的建议是使用nvue
切换了一天,vue swiper video很完美
开心。。。。。
下班。。。。。
。。。。。。。
半路
测试说APP无法生成海报
卧槽,nvue不支持canvas
so,我现在又在电脑面前找解决方案
兄弟们
九九孩子

官方的NvueCanvasDemo不是我想要的

看来只能麻烦后台了

收起阅读 »

关于新版本canvasGetImageData报错的解决方法

uniapp

蓝牙打印一直用到uni.canvasGetImageData生成画布,更新新版本后一直报错,现在使用uni.canvasPutImageData替代

               uni.canvasPutImageData({  
                  canvasId: 'prite_area_canvas',  
                  x: 0,  
                  y: 0,  
                  width: canvasWidth,  
                  height: canvasHeight,  
                  data: command.getData(),  
                  success: function(res) {  
                    console.log('success')  
                    command.setBitmap(res)  
                  },  
                  fail:function(){  
                    console.log('fail')  
                  },  
                  complete: function() {  
                    // command.setPrintAndFeedRow(3);  
                    console.log('complete')  
                    that.prepareSend(command.getData());  
                  }  
                })
继续阅读 »

蓝牙打印一直用到uni.canvasGetImageData生成画布,更新新版本后一直报错,现在使用uni.canvasPutImageData替代

               uni.canvasPutImageData({  
                  canvasId: 'prite_area_canvas',  
                  x: 0,  
                  y: 0,  
                  width: canvasWidth,  
                  height: canvasHeight,  
                  data: command.getData(),  
                  success: function(res) {  
                    console.log('success')  
                    command.setBitmap(res)  
                  },  
                  fail:function(){  
                    console.log('fail')  
                  },  
                  complete: function() {  
                    // command.setPrintAndFeedRow(3);  
                    console.log('complete')  
                    that.prepareSend(command.getData());  
                  }  
                })
收起阅读 »

Vue.js自定义垂直/水平滚动条组件|vue模拟滚动条

vue.js

介绍

VScroll滚动条 基于vuejs2.x构建的美化XY轴滚动条组件。支持原生滚动条、鼠标移出是否隐藏滚动条、自定义滚动条尺寸、颜色及层级等功能。拥有漂亮且流畅的滚动体验!

vue.js仿饿了么滚动条组件|vue自定义滚动条

img
img

参数配置

props: {  
    // 是否显示原生滚动条  
    native: Boolean,  
    // 是否自动隐藏滚动条  
    autohide: Boolean,  
    // 滚动条尺寸  
    size: { type: [Number, String], default: '' },  
    // 滚动条颜色  
    color: String,  
    // 滚动条层级  
    zIndex: null  
},

img

快速引入

在main.js中引入组件。

import VScroll from './components/vscroll';  
Vue.use(VScroll);

使用组件

<!-- 支持原生滚动条 -->  
<v-scroll native>  
    <img src="https://cn.vuejs.org/images/logo.png" />  
    <p>这里是自定义内容。这里是自定义内容。这里是自定义内容。</p>  
</v-scroll>  

<!-- 参数配置 -->  
<v-scroll autohide size="15" color="#00a1e0" zIndex="2021">  
    <img src="https://cn.vuejs.org/images/logo.png" />  
    <p>这里是自定义内容。这里是自定义内容。这里是自定义内容。</p>  
</v-scroll>

img

img

实现过程

// vscroll模板  
<template>  
  <div class="vui__scrollbar" ref="ref__box" @mouseenter="handleMouseEnter" @mouseleave="handleMouseLeave" v-resize="handleResize">  
    <div :class="['vscroll__wrap', {native: native}]" ref="ref__wrap" @scroll="handleScroll">  
      <div class="vscroll__view" v-resize="handleResize"><slot /></div>  
    </div>  
    <!-- //水平|垂直滚动条 -->  
    <div :class="['vscroll__bar vertical', {ishide: !isShow}]" @mousedown="handleClickTrack($event, 0)" :style="{'width': parseInt(size)>=0 ? parseInt(size)+'px' : '', 'z-index': parseInt(zIndex)>=0 ? parseInt(zIndex) : ''}">  
      <div class="vscroll__thumb" ref="ref__barY" :style="{'background': color, 'height': barHeight+'px'}" @mousedown="handleDragThumb($event, 0)"></div>  
    </div>  
    <div :class="['vscroll__bar horizontal', {ishide: !isShow}]" @mousedown="handleClickTrack($event, 1)" :style="{'height': parseInt(size)>=0 ? parseInt(size)+'px' : '', 'z-index': parseInt(zIndex)>=0 ? parseInt(zIndex) : ''}">  
      <div class="vscroll__thumb" ref="ref__barX" :style="{'background': color, 'width': barWidth+'px'}" @mousedown="handleDragThumb($event, 1)"></div>  
    </div>  
  </div>  
</template>
/**  
 * @Desc     VueJs虚拟滚动条组件VScroll  
<script>  
  import domUtils from './utils/dom'  
  export default {  
    props: {  
      // 显示原生滚动条  
      native: Boolean,  
      // 自动隐藏滚动条  
      autohide: Boolean,  
      // 滚动条尺寸  
      size: { type: [Number, String], default: '' },  
      // 滚动条颜色  
      color: String,  
      // 滚动条层级  
      zIndex: null  
    },  
    data() {  
      return {  
        barWidth: 0,            // 滚动条宽度  
        barHeight: 0,           // 滚动条高度  
        ratioX: 1,              // 滚动条水平偏移率  
        ratioY: 1,              // 滚动条垂直偏移率  
        isTaped: false,         // 鼠标光标是否按住滚动条  
        isHover: false,         // 鼠标光标是否悬停在滚动区  
        isShow: !this.autohide, // 是否显示滚动条  
      }  
    },  
    mounted() {  
      this.$ref__box = this.$refs.ref__box  
      this.$ref__wrap = this.$refs.ref__wrap  
      this.$ref__barY = this.$refs.ref__barY  
      this.$ref__barX = this.$refs.ref__barX  
      this.$nextTick(this.updated)  
    },  
    // ...  
    methods: {  
      // 鼠标移入  
      handleMouseEnter() {  
        this.isHover = true  
        this.isShow = true  
        this.updated()  
      },  

      // 鼠标移出  
      handleMouseLeave() {  
        this.isHover = false  
        this.isShow = false  
      },  

      // 拖动滚动条  
      handleDragThumb(e, index) {  
        let _this = this  
        this.isTaped = true  
        let c = {}  

        domUtils.isIE() ? (e.returnValue = false, e.cancelBubble = true) : (e.stopPropagation(), e.preventDefault())  
        document.onselectstart = () => false  

        if(index == 0) {  
          c.dragY = true  
          c.clientY = e.clientY  
        }else {  
          c.dragX = true  
          c.clientX = e.clientX  
        }  

        domUtils.on(document, 'mousemove', function(evt) {  
          if(_this.isTaped) {  
            if(c.dragY) {  
              _this.$ref__wrap.scrollTop += (evt.clientY - c.clientY) * _this.ratioY  
              _this.$ref__barY.style.transform = `translateY(${_this.$ref__wrap.scrollTop / _this.ratioY}px)`  
              c.clientY = evt.clientY  
            }  
            if(c.dragX) {  
              _this.$ref__wrap.scrollLeft += (evt.clientX - c.clientX) * _this.ratioX  
              _this.$ref__barX.style.transform = `translateX(${_this.$ref__wrap.scrollLeft / _this.ratioX}px)`  
              c.clientX = evt.clientX  
            }  
          }  
        })  
        domUtils.on(document, 'mouseup', function() {  
          _this.isTaped = false  

          document.onmouseup = null;  
          document.onselectstart = null  
        })  
      },  

      // 滚动槽  
      handleClickTrack(e, index) {  
        console.log(index)  
      },  

      // 更新滚动  
      updated() {  
        if(this.native) return  

        // 垂直滚动条  
        if(this.$ref__wrap.scrollHeight > this.$ref__wrap.offsetHeight) {  
          this.barHeight = this.$ref__box.offsetHeight **2 / this.$ref__wrap.scrollHeight  
          this.ratioY = (this.$ref__wrap.scrollHeight - this.$ref__box.offsetHeight) / (this.$ref__box.offsetHeight - this.barHeight)  
          this.$ref__barY.style.transform = `translateY(${this.$ref__wrap.scrollTop / this.ratioY}px)`  
        }else {  
          this.barHeight = 0  
          this.$ref__barY.style.transform = ''  
          this.$ref__wrap.style.marginRight = ''  
        }  

        // 水平滚动条  
        ...  
      },  

      handleResize() {  
        // 更新滚动条状态  
      },  

      // ...  
    }  
  }  
</script>

vue中directives指令函数监听DOM变化。

// 监听元素/DOM尺寸变化  
directives: {  
    'resize': {  
        bind: function(el, binding) {  
            let width = '', height = '';  
            function get() {  
            const elStyle = el.currentStyle ? el.currentStyle : document.defaultView.getComputedStyle(el, null);  
            if (width !== elStyle.width || height !== elStyle.height) {  
                binding.value({width, height});  
            }  
            width = elStyle.width;  
            height = elStyle.height;  
            }  
            el.__vueReize__ = setInterval(get, 16);  
        },  
        unbind: function(el) {  
            clearInterval(el.__vueReize__);  
        }  
    }  
}

img

img

好了,今天就分享到这里。希望大家能喜欢哈!

基于vue.js网页弹窗组件|vue自定义对话框VLayer

img

链接:https://juejin.cn/post/6901103494971785223/
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

继续阅读 »

介绍

VScroll滚动条 基于vuejs2.x构建的美化XY轴滚动条组件。支持原生滚动条、鼠标移出是否隐藏滚动条、自定义滚动条尺寸、颜色及层级等功能。拥有漂亮且流畅的滚动体验!

vue.js仿饿了么滚动条组件|vue自定义滚动条

img
img

参数配置

props: {  
    // 是否显示原生滚动条  
    native: Boolean,  
    // 是否自动隐藏滚动条  
    autohide: Boolean,  
    // 滚动条尺寸  
    size: { type: [Number, String], default: '' },  
    // 滚动条颜色  
    color: String,  
    // 滚动条层级  
    zIndex: null  
},

img

快速引入

在main.js中引入组件。

import VScroll from './components/vscroll';  
Vue.use(VScroll);

使用组件

<!-- 支持原生滚动条 -->  
<v-scroll native>  
    <img src="https://cn.vuejs.org/images/logo.png" />  
    <p>这里是自定义内容。这里是自定义内容。这里是自定义内容。</p>  
</v-scroll>  

<!-- 参数配置 -->  
<v-scroll autohide size="15" color="#00a1e0" zIndex="2021">  
    <img src="https://cn.vuejs.org/images/logo.png" />  
    <p>这里是自定义内容。这里是自定义内容。这里是自定义内容。</p>  
</v-scroll>

img

img

实现过程

// vscroll模板  
<template>  
  <div class="vui__scrollbar" ref="ref__box" @mouseenter="handleMouseEnter" @mouseleave="handleMouseLeave" v-resize="handleResize">  
    <div :class="['vscroll__wrap', {native: native}]" ref="ref__wrap" @scroll="handleScroll">  
      <div class="vscroll__view" v-resize="handleResize"><slot /></div>  
    </div>  
    <!-- //水平|垂直滚动条 -->  
    <div :class="['vscroll__bar vertical', {ishide: !isShow}]" @mousedown="handleClickTrack($event, 0)" :style="{'width': parseInt(size)>=0 ? parseInt(size)+'px' : '', 'z-index': parseInt(zIndex)>=0 ? parseInt(zIndex) : ''}">  
      <div class="vscroll__thumb" ref="ref__barY" :style="{'background': color, 'height': barHeight+'px'}" @mousedown="handleDragThumb($event, 0)"></div>  
    </div>  
    <div :class="['vscroll__bar horizontal', {ishide: !isShow}]" @mousedown="handleClickTrack($event, 1)" :style="{'height': parseInt(size)>=0 ? parseInt(size)+'px' : '', 'z-index': parseInt(zIndex)>=0 ? parseInt(zIndex) : ''}">  
      <div class="vscroll__thumb" ref="ref__barX" :style="{'background': color, 'width': barWidth+'px'}" @mousedown="handleDragThumb($event, 1)"></div>  
    </div>  
  </div>  
</template>
/**  
 * @Desc     VueJs虚拟滚动条组件VScroll  
<script>  
  import domUtils from './utils/dom'  
  export default {  
    props: {  
      // 显示原生滚动条  
      native: Boolean,  
      // 自动隐藏滚动条  
      autohide: Boolean,  
      // 滚动条尺寸  
      size: { type: [Number, String], default: '' },  
      // 滚动条颜色  
      color: String,  
      // 滚动条层级  
      zIndex: null  
    },  
    data() {  
      return {  
        barWidth: 0,            // 滚动条宽度  
        barHeight: 0,           // 滚动条高度  
        ratioX: 1,              // 滚动条水平偏移率  
        ratioY: 1,              // 滚动条垂直偏移率  
        isTaped: false,         // 鼠标光标是否按住滚动条  
        isHover: false,         // 鼠标光标是否悬停在滚动区  
        isShow: !this.autohide, // 是否显示滚动条  
      }  
    },  
    mounted() {  
      this.$ref__box = this.$refs.ref__box  
      this.$ref__wrap = this.$refs.ref__wrap  
      this.$ref__barY = this.$refs.ref__barY  
      this.$ref__barX = this.$refs.ref__barX  
      this.$nextTick(this.updated)  
    },  
    // ...  
    methods: {  
      // 鼠标移入  
      handleMouseEnter() {  
        this.isHover = true  
        this.isShow = true  
        this.updated()  
      },  

      // 鼠标移出  
      handleMouseLeave() {  
        this.isHover = false  
        this.isShow = false  
      },  

      // 拖动滚动条  
      handleDragThumb(e, index) {  
        let _this = this  
        this.isTaped = true  
        let c = {}  

        domUtils.isIE() ? (e.returnValue = false, e.cancelBubble = true) : (e.stopPropagation(), e.preventDefault())  
        document.onselectstart = () => false  

        if(index == 0) {  
          c.dragY = true  
          c.clientY = e.clientY  
        }else {  
          c.dragX = true  
          c.clientX = e.clientX  
        }  

        domUtils.on(document, 'mousemove', function(evt) {  
          if(_this.isTaped) {  
            if(c.dragY) {  
              _this.$ref__wrap.scrollTop += (evt.clientY - c.clientY) * _this.ratioY  
              _this.$ref__barY.style.transform = `translateY(${_this.$ref__wrap.scrollTop / _this.ratioY}px)`  
              c.clientY = evt.clientY  
            }  
            if(c.dragX) {  
              _this.$ref__wrap.scrollLeft += (evt.clientX - c.clientX) * _this.ratioX  
              _this.$ref__barX.style.transform = `translateX(${_this.$ref__wrap.scrollLeft / _this.ratioX}px)`  
              c.clientX = evt.clientX  
            }  
          }  
        })  
        domUtils.on(document, 'mouseup', function() {  
          _this.isTaped = false  

          document.onmouseup = null;  
          document.onselectstart = null  
        })  
      },  

      // 滚动槽  
      handleClickTrack(e, index) {  
        console.log(index)  
      },  

      // 更新滚动  
      updated() {  
        if(this.native) return  

        // 垂直滚动条  
        if(this.$ref__wrap.scrollHeight > this.$ref__wrap.offsetHeight) {  
          this.barHeight = this.$ref__box.offsetHeight **2 / this.$ref__wrap.scrollHeight  
          this.ratioY = (this.$ref__wrap.scrollHeight - this.$ref__box.offsetHeight) / (this.$ref__box.offsetHeight - this.barHeight)  
          this.$ref__barY.style.transform = `translateY(${this.$ref__wrap.scrollTop / this.ratioY}px)`  
        }else {  
          this.barHeight = 0  
          this.$ref__barY.style.transform = ''  
          this.$ref__wrap.style.marginRight = ''  
        }  

        // 水平滚动条  
        ...  
      },  

      handleResize() {  
        // 更新滚动条状态  
      },  

      // ...  
    }  
  }  
</script>

vue中directives指令函数监听DOM变化。

// 监听元素/DOM尺寸变化  
directives: {  
    'resize': {  
        bind: function(el, binding) {  
            let width = '', height = '';  
            function get() {  
            const elStyle = el.currentStyle ? el.currentStyle : document.defaultView.getComputedStyle(el, null);  
            if (width !== elStyle.width || height !== elStyle.height) {  
                binding.value({width, height});  
            }  
            width = elStyle.width;  
            height = elStyle.height;  
            }  
            el.__vueReize__ = setInterval(get, 16);  
        },  
        unbind: function(el) {  
            clearInterval(el.__vueReize__);  
        }  
    }  
}

img

img

好了,今天就分享到这里。希望大家能喜欢哈!

基于vue.js网页弹窗组件|vue自定义对话框VLayer

img

链接:https://juejin.cn/post/6901103494971785223/
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

收起阅读 »

uni-app 广告心得

每天开屏展示pv 500 , 点击 50 。收益0.1-0.4. 大家自己体会分析

每天开屏展示pv 500 , 点击 50 。收益0.1-0.4. 大家自己体会分析

做外包做私活的同学们来吧

支付宝小程序 微信小程序 小程序

小程序开发交流群

群号:374213882

小程序开发交流群

群号:374213882

曝光个小人!发个接外包的贴被同行诬蔑 加他微信问为什么被瞬间拉黑

招聘 uni_app 外包 uniapp

他回帖道歉说认错人了,那就算了吧!

他回帖道歉说认错人了,那就算了吧!

快手点赞APP系统开发

App

APP作为一种有效的工具,企业级( myxsky366 ,马先生)APP已成为企业在移动终端上的竞争平台。它与网站微博和微信一起构成了新媒体营销的“三驾马车”。越来越多的企业看到企业APP对企业有效开发,市场营销等方面的优势,通过开发,市场营销等带来的优势,认识到企业移动app的市场营销价值以及抓住用户移动终端桌面的重要性,并希望利用APP实现与用户零距离绑定。对于企业而言,选择开发自己的或将自己的企业APP外包是没有时间延迟的。

继续阅读 »

APP作为一种有效的工具,企业级( myxsky366 ,马先生)APP已成为企业在移动终端上的竞争平台。它与网站微博和微信一起构成了新媒体营销的“三驾马车”。越来越多的企业看到企业APP对企业有效开发,市场营销等方面的优势,通过开发,市场营销等带来的优势,认识到企业移动app的市场营销价值以及抓住用户移动终端桌面的重要性,并希望利用APP实现与用户零距离绑定。对于企业而言,选择开发自己的或将自己的企业APP外包是没有时间延迟的。

收起阅读 »

六度空间系统开发源码

六度空间系统开发源码咨询王经理l83薇35lO電4692,六度空间源码开发介绍,六度空间APP开发
六度空间系统介绍
六度分割虽然是个社会学的理论,但是实际上它更像一个数学理论,很多人说它和四色问题有异曲同工之妙。在我看来,六度分割很好的阐述了一个网状的结构(我们的人类社会),增强了不同节点之间的联系和连接关系,然而它并不完整,也并不足以指导我们的实践。但这个理论在很大程度上让人们对于信息时代的人类社会有了很深的理解与探索。

继续阅读 »

六度空间系统开发源码咨询王经理l83薇35lO電4692,六度空间源码开发介绍,六度空间APP开发
六度空间系统介绍
六度分割虽然是个社会学的理论,但是实际上它更像一个数学理论,很多人说它和四色问题有异曲同工之妙。在我看来,六度分割很好的阐述了一个网状的结构(我们的人类社会),增强了不同节点之间的联系和连接关系,然而它并不完整,也并不足以指导我们的实践。但这个理论在很大程度上让人们对于信息时代的人类社会有了很深的理解与探索。

收起阅读 »

老司机开车

外包

v9个人承接vue、uniapp项目,有案例,联系1819080149,不接受外地工作,可付费提供技术支持。添加QQ时务必备注来意以及添加渠道,渠道可以写:uniapp

v9个人承接vue、uniapp项目,有案例,联系1819080149,不接受外地工作,可付费提供技术支持。添加QQ时务必备注来意以及添加渠道,渠道可以写:uniapp

前端uniapp 后端php影视二开 要求有经验的来

外包

前端uniapp 后端php影视二开 要求有经验的来q1836666856

前端uniapp 后端php影视二开 要求有经验的来q1836666856

商城小程序开发

可基于uni-app 的开源商城案例基础上开发,只负责前端开发。不负责接口和后台开发。

地址在上海需要能线下见面。

有兴趣的同学添加微信:yetu_hare

可基于uni-app 的开源商城案例基础上开发,只负责前端开发。不负责接口和后台开发。

地址在上海需要能线下见面。

有兴趣的同学添加微信:yetu_hare