酷站(www.ku0.com)-致力于为互联网从业者提供动力!

热门关键词:  企业  as  baidu  c4rp3nt3r  美女
酷站

【云小站】新老客都返现+现金红包+瓜分60万奖池
酷站

css

旗下栏目: html css xml html5 DW bootstrap Frontpage教程

详解css实现环形/扇形菜单(基础版)

来源:互联网搜集 作者:秩名 人气: 发布时间:2020-01-16
本篇文章主要介绍了详解css实现环形/扇形菜单(基础版),对大家的学习或者工作具有一定的参考学习价值,感兴趣的小伙伴们可以参考一下,也感谢大家对酷站(ku0.com)的支持。

项目需要用到环形菜单,初略在网上找了一下,没有找到合适的,于是自己写了一个很简单的,后续再优化。

这个组件是基于react,但是原理都一样。

展开效果如下:

 


 

实现

css(less)
 

@centerIconSize: 30px;
 
.flex(@justify: flex-start, @align: center) {
    justify-content: @justify;
    align-items: @align;
    display: flex;
}
.sector-menu-wrapper {
    position: relative;
    width: @centerIconSize;
    margin: auto;
 
    .center-icon {
        .flex(center);
        width: @centerIconSize;
        height: @centerIconSize;
        border-radius: 50%;
        background: rgba(0, 0, 0, 0.3);
        color: white;
        cursor: pointer;
    }
 
    .sector-item {
        position: absolute;
        .flex(center);
        width: @centerIconSize;
        height: @centerIconSize;
        border-radius: 50%;
        background: rgba(0, 0, 0, 0.3);
        cursor: pointer;
        color: white;
        top: 0;
        left: 0;
        transition: all linear 0.5s;
        transform: translate(0, 0);
        // display: none;
        visibility: hidden;
    }
 
    .sector-list {
        &.sector-list-active {
            transition: all linear 0.5s;
            .sector-item {
                .flex(center);
                transition: all linear 0.5s;
                transform: translate(0, 0);
                visibility: visible;
 
                &:first-child {
                    transform: translate(0, -@centerIconSize * 1.5);
                }
         
                &:nth-child(2) {
                    transform: translate(-@centerIconSize * 1.5, 0);
                }
         
                &:nth-child(3) {
                    transform: translate(0, @centerIconSize * 1.5);
                     
                }
            }
        }
    }
}

SectorMenu.js

import React from 'react';
 
export default class SectorMenu extends React.Component {
    state = {
        direction: 'left',
        sectorMenuVisible: false,
        centerIconSize: 30,
        sectorItemSize: 30,
    }
 
    /**
     * 显示环形菜单
     */
    showSectorMenu = () => {
        const { sectorMenuVisible } = this.state;
        this.setState({
            sectorMenuVisible: !sectorMenuVisible,
        })
    }
 
    onClickSectorMenuItem = (index) => {
        const { sectorMenuItemFunctions } = this.props;
        if (!sectorMenuItemFunctions || typeof(sectorMenuItemFunctions[index]) !== 'function') {
            return;
        }
        sectorMenuItemFunctions[index]();
    }
 
    getSectorJsx = () => {
        const { sectorMenuItems } = this.props;
 
        if (!sectorMenuItems || !Array.isArray(sectorMenuItems) || sectorMenuItems.length === 0) {
            return;
        }
 
        const styles = {};
        const {  sectorMenuVisible } = this.state;
 
        return sectorMenuItems.map((item, i) => {
            // const styles = {
            //     transform: translate(0, -centerIconSize * 2);
            // };
 
            return (<div
                className={`sector-item ${sectorMenuVisible && 'sector-item-active'}`}
                style={styles}
                onClick={() => this.onClickSectorMenuItem(i)}
                key={i}
            >
                {item}
            </div>)
        });
    }
    render() {
        const { sectorMenuVisible } = this.state;
        return (
            <div className="sector-menu-wrapper">
                <div className="center-icon" onClick={this.showSectorMenu}>
                    {
                        sectorMenuVisible ? 'x' : '···'
                    }
                </div>
                <div className={`sector-list ${sectorMenuVisible && 'sector-list-active'}`}>
                    {this.getSectorJsx()}
                </div>
            </div>
        )
    }
}

调用

<SectorMenu
    sectorMenuItems={['A1', 'A2', 'A3']}
    sectorMenuItemFunctions={[function () {console.log(0)}, function () {console.log(1)}, function () {console.log(2)}]}
/>

期望

本来是想写成灵活分布,在怎么计算位置这里稍稍卡了一下,项目时间紧,改天抽空优化一下

  1. 灵活布局sectorMenuItem
  2. 灵活展示SectorMenu的位置(left,right, top, bottom...)


踩坑

过渡动画一直没有用,后来才知道是我在sector-item这个类里使用了display:none导致的,改用visibility属性就可以了。

版权声明:本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 959677720#qq.cn(#换@) 举报,一经查实,本站将立刻删除。

您可能感兴趣的文章:

原文链接:https://www.jb51.net/css/710345.html

相关文章

  • 解决CSS3关于z-index不生效问题

    解决CSS3关于z-index不生效问题

    最近写CSS3和js结合,遇到了很多次z-index不生效的情况: 1.在用z-index的时候,该元素没有定位(static定位除外) 2.在有定位的情况下,该元素的z-index没有生效,是因为该元素的子元素后来居上,盖住了该元素,解决方式:将盖住该元素......
    02-19
  • border-radius IE8兼容处理的方法介绍

    border-radius IE8兼容处理的方法介绍

    根据canisue( http://caniuse.com/#search=border-radius ),border-radius兼容性如下图所示: 测试代码: !DOCTYPE htmlhtml head meta charset=UTF-8 meta http-equiv=X-UA-Compatible content=IE=edge,chrome=1 title/title style t......
    02-13
  • css实现3d立体魔方

    css实现3d立体魔方

    今天来做一个简单的3d魔方 先看效果图吧!把这个看会了,一些网上的3d的相册你就都会了 一,html代码 !DOCTYPE htmlhtml lang=zh-CN head title3d立体魔方/title meta charset=UTF-8 /head body div class=top/div !--上 -- div class=bo......
    02-07
  • 详解css实现环形/扇形菜单(基础版)

    详解css实现环形/扇形菜单(基础版)

    项目需要用到环形菜单,初略在网上找了一下,没有找到合适的,于是自己写了一个很简单的,后续再优化。 这个组件是基于react,但是原理都一样。 展开效果如下: 实现 css(less) @centerIconSize: 30px; .flex(@justify: flex-start, @alig......
    01-16
  • 26个常用易忘CSS小技巧介绍

    26个常用易忘CSS小技巧介绍

    收集于平时常用但易忘的CSS实现方法,如有遗漏或补充,还请指正! 解决inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移 .wrap { display: inline-block; overflow: hidden vertical-align: bottom}.wrap { display: in......
    12-31
  • flex布局中flex-grow与flex-shrink的计算方式解析

    flex布局中flex-grow与flex-shrink的计算方式解析

    CSS 中的 Flex(弹性布局) 可以很灵活的控制网页的布局,其中决定 Flex 布局内项目宽度/高度的是三个属性:flex-basis, flex-grow, flex-shrink. flex-basis flex-basis 决定了项目占据主轴的空间,除非使用 box-sizing 进行设置,否则它......
    12-18
  • better-scroll实现菜单和内容联动的效果

    better-scroll实现菜单和内容联动的效果

    1、基本使用 !DOCTYPE htmlhtml lang=enhead meta charset=UTF-8 meta name=viewport content=width=device-width, initial-scale=1.0 meta http-equiv=X-UA-Compatible content=ie=edge titleDocument/title link href=https://unpkg.co......
    12-09
  • CSS边框长度控制成果的实现

    CSS边框长度控制成果的实现

    以前需要 边框 长度比容器小一些时,我用div嵌套。厥后发明伪类在实现这个效果时很方便,,只需要一个div就够了,另外调解padding和margin都不会很麻烦。 div class=content-blockdiv class=box-containerdiv class=border-topborder top......
    11-29
  • CSS3实现图片抽屉式效果的方法

    CSS3实现图片抽屉式效果的方法

    老规矩,先放图片效果图: 这个效果实现原理很简单:只要你掌握css3动画和过渡相关知识就行,不用js代码; HTML代码: div ul id=list li a href=国际美妆抢先看/a img src=images/1.jpg / /li li a href=女神标准大讨论/a img src=image......
    11-07
  • css :not的多个条件的写法

    css :not的多个条件的写法

    :not 伪类选择器可以筛选不符合表达式的元素 例子 table tbody tr:not(:first-child):not(:last-child) td{ text-align: right;} 以上代码可以选择table表格中tbody部分非首个、非最后一个的tr,并设置其子元素td文本样式居右 这里面需要......
    11-07

最新更新