点击左侧菜单在右侧弹出相应的内容

1:首先我们需要一个主要的页面html的代码

<div id="user_left">
        <div id="dilatation">
            <div id="personal_center">个人中心</div>
        </div>
        <div id="choice">
            <div class="edit" data-id="one"><span class="span c current active_collect" id="w_1" data-src="collect.jsp">我的收藏</span></div>
            <div class="edit" data-id="tow"><span class="span c" data-src="attention.jsp" id="w_2">我的关注</span></div>
            <div class="edit" data-id="three"><span class="span c" data-src="post.jsp" id="w_3">我的发帖</span></div>
            <div class="edit" data-id="four"><span class="span c" data-src="resource.jsp" id="w_4">编辑资料</span></div>
            <div class="edit" data-id="five"><span class="span">退出登录</span></div>
        </div>
    </div>
    <div id="user_right">
        <div class="user_headline_right">
            <div class="user_iron">收藏</div>
        </div>
        <div id="details_user">
            收藏内容
        </div>
    </div>

2:因为有css的样式,所以我呈现的效果是这个样子,以下面的个人中心开始

 3:因为我这里有四个区域需要替换,所以我们需要在创建新的4个html页面,来替换对应的内容区域

<html>
<head>
    <title>收藏</title>
</head>
<body>
    <div id="sc">收藏</div>
    <div id="collect_user">
        收藏内容
    </div>
</body>
</html>
<html>
<head>
    <title>关注</title>
</head>
<body>
<div id="gz">关注</div>
<div id="attention_user">
    关注内容
</div>
</body>
</html>
<html>
<head>
    <title>发帖</title>
</head>
<body>
    <div id="ft">发帖</div>
    <div id="post_user">
        发帖内容
    </div>
</body>
</html>
<html>
<head>
    <title>资料</title>
</head>
<body>
<div id="zl">资料</div>
<div id="resource_user">
    资料内容
</div>
</body>
</html>

4:以上代码就是相应的每一个html页面的代码

5:最后就是主页html的js的代码

// 左侧栏控制右侧内容
function handoffMain() {
    // $("#details_user").load("collect.jsp");
    // 这里的urls,url为你需要替换的html页面的路径和某个div的对应id
    let urls = ["collect.jsp #collect_user",
        "attention.jsp #attention_user",
        "post.jsp #post_user",
        "resource.jsp #resource_user"]
    let url = ["collect.jsp #sc",
        "attention.jsp #gz",
        "post.jsp #ft",
        "resource.jsp #zl"]
    let lists = document.getElementsByClassName("c");
    for (let i = 0; i < lists.length; i++) {
        // let state = {
        //     index: i,
        //     name: urls[i]
        // }
        lists[i].addEventListener("click", function () {
            $("#details_user").load(urls[i]);
            $(".user_iron").load(url[i]);
            /*if (this.innerText === "个人资料"){
                requestProfileData();
            }*/
            // window.history.pushState(state, null, urlFiles[i]);
            setTimeout(function () {
                let elements = [document.getElementById("w_1"),
                    document.getElementById("w_2"),
                    document.getElementById("w_3"),
                    document.getElementById("w_4")];
                elements[i].removeAttribute("style");
            }, 200);
        });
    }
}
//默认收藏变换颜色,这个就是点击改变对应的颜色
function collect() {
    $(".span").click(function () {
        // $(this).addClass('active').siblings().removeClass('active');collect
        $(".span").removeClass("active_collect").removeAttr("style");
        $(this).addClass("active_collect").css("color","rgb(0, 195, 255)");
    });
    
}

最后我们看看效果图吧!

 

 如果需要css代码样式的,或者有什么不完整的可以私信我,发完整的代码

  • 7
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: Qt Designer是一个可视化的图形用户界面设计工具,用于创建Qt应用程序的界面。在Qt Designer中,可以通过简单的拖拽和放置操作创建GUI界面,然后使用代码将界面和应用程序逻辑连接起来。 要在Qt Designer中添加右键弹出菜单栏,可以按照以下步骤进行操作: 1. 打开Qt Designer并创建一个新的窗口小部件(QWidget)。 2. 在左侧的“对象库”面板中,找到并拖放一个“QMenu”小部件到窗口中。 3. 右键单击窗口,并选择“添加动作”来添加菜单项(QAction)。 4. 在右侧的“属性编辑器”面板中,为菜单项设置文本、图标等属性。 5. 右键单击窗口,选择“添加动作组”,将菜单项添加到动作组中。 6. 右键单击菜单小部件,选择“编辑动作”以显示动作编辑器。 7. 在动作编辑器中,将动作组添加到菜单小部件中。 8. 将要弹出菜单的控件与菜单小部件连接起来。可以选择窗口的某个控件,右键单击,选择“快捷方式”->“添加右键菜单”,然后选择菜单小部件作为要弹出菜单的对象。 9. 保存并关闭Qt Designer,然后使用Qt代码将界面加载到应用程序中。 在应用程序中,当用户在要弹出菜单的控件上右键单击时,菜单将会显示出来。可以通过在代码中连接菜单项的信号与相应的槽函数,来处理用户的操作。 以上是使用Qt Designer添加右键弹出菜单栏的大致步骤,根据具体的需求和界面设计,可能会有一些细节上的差异或额外的操作。通过灵活运用Qt Designer的功能和Qt的编程接口,可以方便地实现各种复杂的界面交互效果。 ### 回答2: Qt Designer是Qt框架下的一个可视化界面设计工具,可以通过拖拽和布局的方式设计用户界面,并通过生成相应的源代码实现界面的功能。 在Qt Designer中实现右键弹出菜单栏的步骤如下: 1. 在界面中添加一个QMenu控件,作为右键菜单的容器。 2. 在界面中添加需要右键操作的控件,例如一个QPushButton。 3. 选中需要右键操作的控件,打开右键弹出菜单的设计师(右键选择Actions)。 4. 在右键弹出菜单的设计师中,点击“+”按钮添加一个QAction,并设置其对应的文本和图标等属性。 5. 重复步骤4,添加多个QAction。 6. 将添加的QAction拖拽到之前添加的QMenu控件上,作为其子控件。 7. 在需要右键操作的控件的鼠标右键PressEvent事件中,添加如下代码: ```cpp void Widget::mousePressEvent(QMouseEvent *event) { if (event->button() == Qt::RightButton) { QMenu menu; menu.addAction(action1); menu.addAction(action2); menu.exec(event->globalPos()); } } ``` 其中`action1`和`action2`为之前添加的QAction。 8. 通过编译和运行代码,即可在运行界面上右键点击需要右键操作的控件时弹出之前设计的右键菜单。 这样,通过以上步骤就可以在Qt Designer中实现右键弹出菜单栏了。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值