在没有 JQuery 的情况下滑动“阅读更多”功能

如何解决在没有 JQuery 的情况下滑动“阅读更多”功能

是否可以创建一个像这样工作的“阅读更多”按钮:

按钮会是一张照片(我没有这个问题),内容在照片下面(这里,到目前为止,我在位置:绝对原则上做了,可惜显示内容后,其余的页面没有下推,文本本身在下一个 div ' ami 之上)。单击时,文本从照片下方出来,推动其余的容器。当您再次单击时,文本会重新向上,隐藏在照片下方。

很遗憾,显示:无和显示:块或可见等之间的切换功能是不可能的,因为内容必须下坡。

对我来说不使用 jQuery 很重要。

如果我没有解释清楚,我会回答问题,马丁

解决方法

你只能用 CSS 来实现,这里是一个例子:

这个想法是在文本区域之前创建一个带有唯一 ID 的隐藏复选框,然后创建一个带有 for 属性的标签并放置该复选框 ID ,最后使用 CSS 检查复选框是否被选中,如果它被选中,则将特定样式添加到它的下一个元素,例如 #showMore:checked + .someText ,符号 + 表示仅将此样式应用于下一个 .someText 类,在这种情况下class 必须紧跟在复选框之后并在同一个父级内,而符号 ~ 表示将此样式应用于属于同一父级的所有 .theButton 类。

.someText{
  height:50px;
  overflow:hidden;
  display:block;
  padding:10px;
  border:1px solid #444;
}

.theButton{
  background: #444;
  color:#fff;
  padding:10px;
  display:block;
  width:100px;
  margin:10px auto;
  text-align:center;
  cursor:pointer;
  position:relative;
}

.theButton:after{
  content:"Read More";
}

#showMore:checked + .someText{
  height:100%;
}

#showMore:checked ~ .theButton:after{
 content:"Read Less";
}
<input type="checkbox" id="showMore" hidden />
<div class="someText">
Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s,when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries,but also the leap into electronic typesetting,remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages,and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.
Why do we use it?
It is a long established fact that a reader will be distracted by the readable content of a page when looking at its layout. The point of using Lorem Ipsum is that it has a more-or-less normal distribution of letters,as opposed to using 'Content here,content here',making it look like readable English. Many desktop publishing packages and web page editors now use Lorem Ipsum as their default model text,and a search for 'lorem ipsum' will uncover many web sites still in their infancy. Various versions have evolved over the years,sometimes by accident,sometimes on purpose (injected humour and the like).
</div>
<label class="theButton" for="showMore"></label>

,

如果您在向下推内容的同时尝试隐藏和显示文本(并且具有硬编码的高度是可以的),这里有一个基于您的代码的选项。这使用了类似于 @Ahmed Tag Amer 的复选框方法,并修复了可访问性(不透明度/位置而不是显示:隐藏)和元素顺序的变化。

我使用 <input type="checkbox"><label> 来确定元素是显示还是隐藏(未选中或选中的输入属性),并使用 z-index values 将元素定位到其父元素中。>

注意:我没有用浏览器检查这种方法的兼容性。

* {
    margin: 0;
    padding: 0;
    font-family: Open Sans;
    font-size: 16px;
    box-sizing: border-box;
}

.container {
    width: 500px;
    margin: auto;
    background-color: grey;
    padding: 0;
}
#firstButtonCheck {
    position: absolute;
    opacity: 0;
}
#firstButtonCheck ~ .firstContent {
    background-color: yellow;
    margin-top: -500px;
    width: 500px;
    height: 500px;
    max-height: 500px;
    display: block;
    padding: 5px;
    transition: margin-top 1s ease-out,max-height 1s ease-out;
}
.firstButton {
    display: block;
    height: 500px;
    width: 500px;
    background-color: red;
    cursor: pointer;
    position: relative;
    z-index: 2;
}

#firstButtonCheck:checked ~ .firstContent {
    margin-top: 0px;
    height: 500px;
    max-height: 500px;
    transition: margin-top 1s ease-out,max-height 1s ease-out;
}


#secondButtonCheck {
    position: absolute;
    opacity: 0;
}
#secondButtonCheck ~ .secondContent {
    background-color: grey;
    margin-top: -500px;
    width: 500px;
    height: 500px;
    max-height: 500px;
    display: block;
    padding: 5px;
    transition: margin-top 1s ease-out,max-height 1s ease-out;
}
.secondButton {
    display: block;
    height: 500px;
    width: 500px;
    background-color: green;
    cursor: pointer;
    position: relative;
    z-index: 1;
}

#secondButtonCheck:checked ~ .secondContent {
    margin-top: 0px;
    height: 500px;
    max-height: 500px;
    transition: margin-top 1s ease-out,max-height 1s ease-out;
}
.secondContent {
    height: 500px;
}
<div class="container">
    <input type="checkbox" id="firstButtonCheck" />
    <label class="firstButton" for="firstButtonCheck">Picture Here</label>
    <div class="firstContent">
        <h1>First Content</h1>
        Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s,when an unknown printer took a galley of type and scrambled it to make a type specimen book.   </div>
    <input type="checkbox" id="secondButtonCheck" />
    <label class="secondButton" for="secondButtonCheck">Picture Here</label>
    <div class="secondContent">
        <h1>Second Content</h1>
        Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s,when an unknown printer took a galley of type and scrambled it to make a type specimen book.   </div>
    </div>
</div>

,

这是我想象的。您可以复制此代码,它已完成。不幸的是,第一个容器的内容不是压下第二个容器而是覆盖它。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<style>
    * {
        margin: 0;
        padding: 0;
        font-family: Open Sans;
        font-size: 16px;
    }
    
    .container {
        width: 500px;
        margin: 0 auto;
        height: 1000px;
        background-color: grey;
    }
    
    .first {
        position: relative;
    }
    
    .firstButton {
        position: absolute;
        height: 500px;
        width: 100%;
        background-color: red;
        z-index: 100;
    }
    
    .firstButton:hover {
        cursor: pointer;
    }
    
    .firstContent {
        width: 100%;
        height: 500px;
        position: absolute;
        top: 0px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 99;
        background-color: yellow;
        transition: 0.5s;
    }
    
    .firstContentShow {
        top: 500px;
    }
    
    .second {
        position: relative;
    }
    
    .secondButton {
        width: 100%;
        height: 500px;
        background-color: green;
        position: absolute;
        z-index: 98;
    }
</style>
</head>
<body>
<div class="container">
    <div class="first">
        <div class="firstButton" onclick="showFirstContent()"></div>
        <div class="firstContent"></div>
    </div>
    <div class="second">
        <div class="secondButton"></div>
        <div class="secondContent"></div>
    </div>
</div>

<script>

    function showFirstContent() {
        var content = document.querySelector(".firstContent");
        content.classList.toggle("firstContentShow");
    }
    
</script>
</body>
</html>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res