基于Taro的移动端H5的悬浮按钮(可拖动)

今天工作时遇到了一个需求,要去做一个可拖动的悬浮按钮。
查找了资料发现了一个文章然后根据内容进行修改。
添加链接描述
效果图大概是这个样子,然后可以在界面上拖动。
在这里插入图片描述
因为是taro的项目,所以下面的代码是基于taro实现的,最后边会给出原生js的实现代码,如果有错误的地方希望指正出来进行修改

首先是render部分,
拖动的事件分布为:onTouchStart(开始拖动执行的事件),onTouchMove(拖动时执行的事件),onTouchEnd(拖动结束执行的事件)
首先先给view设置固定定位fixed,然后通过控制left和top的属性来设置位置

render() {
  return (
       <View
           className="t-suspend-button"
           onClick={this.handleClick.bind(this)}
           onTouchStart={e => this.onTouchStart(e)}
           onTouchMove={e => this.onTouchMove(e)}
           onTouchEnd={e => this.onTouchEnd(e)}
           style={
  {
           	position: fixe
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您提到的小程序悬浮搜索框可以通过在小程序页面中使用 `navigator` 组件和 `fixed` 定位来实现。具体的实现步骤如下: 1. 在小程序页面的 `json` 文件中添加 `navigator` 组件,设置 `url` 属性为搜索页面的路径,设置 `open-type` 属性为 `navigate`,设置 `hover-class` 属性为 `none`,并在组件内部添加一个 `input` 输入框。 ```json { "usingComponents": { "navigator": "/miniprogram_npm/@tarojs/components/dist/taro-components/taro-components.esm" }, "navigationBarTitleText": "首页", "navigationBarBackgroundColor": "#fff", "navigationBarTextStyle": "black", "enablePullDownRefresh": true, "backgroundTextStyle": "dark", "backgroundColor": "#F5F5F5", "usingComponents": {}, "component": true, "disableScroll": true, "navigationStyle": "custom", "window": { "backgroundTextStyle": "light", "navigationBarBackgroundColor": "#fff", "navigationBarTitleText": "WeChat", "navigationBarTextStyle": "black" }, "usingComponents": { "navigator": "/miniprogram_npm/@tarojs/components/dist/taro-components/taro-components.esm" }, "disableScroll": true, "navigationBarTitleText": "首页", "enablePullDownRefresh": true, "backgroundTextStyle": "dark", "backgroundColor": "#F5F5F5", "usingComponents": {} } ``` 2. 在小程序页面的 `scss` 文件中添加以下样式,设置 `navigator` 组件的位置和样式。 ```scss .navigator { position: fixed; left: 0; top: 0; right: 0; height: 40px; background-color: #fff; z-index: 999; display: flex; justify-content: center; align-items: center; padding: 0 10px; } .navigator input { width: 100%; height: 100%; border: none; outline: none; background-color: transparent; font-size: 14px; color: #333; padding: 0 10px; margin: 0; } ``` 3. 在小程序页面的 `js` 文件中添加以下代码,判断当前页面是否是搜索页面,如果是,则隐藏 `navigator` 组件;否则显示 `navigator` 组件。 ```js import Taro, { Component } from '@tarojs/taro' import { View, Input } from '@tarojs/components' class Index extends Component { config = { navigationBarTitleText: '首页' } state = { isSearchPage: false } onShow() { const pages = Taro.getCurrentPages() const currentPage = pages[pages.length - 1] const isSearchPage = currentPage.route === 'pages/search/search' this.setState({ isSearchPage }) } render() { const { isSearchPage } = this.state return ( <View className='index'> {!isSearchPage && ( <navigator className='navigator' url='/pages/search/search' open-type='navigate' hover-class='none'> <Input className='input' placeholder='请输入搜索内容' /> </navigator> )} <View className='content'>这是首页</View> </View> ) } } export default Index ``` 通过以上步骤,即可实现小程序悬浮搜索框的效果。需要注意的是,由于小程序的一些限制,`navigator` 组件在 iOS 系统下可能会出现样式问题,可以通过在 `app.js` 文件中设置 `window` 对象的 `disableScroll` 属性为 `true` 来解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值