原生JS获取元素集合的子元素宽度实例

发布时间 - 2026-01-10 21:49:38    点击率:

有些时候,在一个网页的ul li中,存在左右两个部分的内容,但是右边元素内容又是不固定,左边元素相对应的不能用固定宽度,所有需要我们动态的获取右边元素宽度,来赋值给左边元素的marginRight值。

HTML结构:

<ul class="itemCon">
  <li class="item">
    <div class="leftMess">
      <div class="leftCon">
        <span>头像</span>
        <p>名字名字名字名字名字名字名字名字名字名字名字名字名字名字名字名字</p>
      </div>
    </div>
    <div class="rightMess">
      <span>工具1</span>
      <span>工具2</span>
      <span>工具3</span>
    </div>
  </li>
  <li class="item">
    <div class="leftMess">
      <div class="leftCon">
        <span>头像</span>
        <p>名字名字名字名字名字名字名字名字名字名字名字名字名字名字名字名字</p>
      </div>
    </div>
    <div class="rightMess">
      <span>工具2</span>
      <span>工具3</span>
    </div>
  </li>
  <li class="item" id="test">
    <div class="leftMess">
      <div class="leftCon">
        <span>头像</span>
        <p>名字名字名字名字名字名字名字名字名字名字名字名字名字名字名字名字</p>
      </div>
    </div>
    <div class="rightMess">
      <span>工具3</span>
    </div>
  </li>
</ul>

配上CSS:

html,body{padding:0;margin:0}
ul,li{list-style:none;padding:0;margin:0}
p{margin:0;padding:0}
.itemCon{width:450px;height:auto; margin:100px auto; background:#ccc; overflow:hidden}
.item{width:100%; float:left;height:60px;border-bottom:solid 1px #f00; position:relative}
.leftMess{ height:60px;}
.leftCon{ float:left; height:60px; overflow:hidden;width:100%}
.leftMess span{ display:inline-block;width:50px;height:50px; border-radius:50%; background:#f00; text-align:center; line-height:50px; margin:5px; float:left}
.leftMess p{ margin-left:60px}
.rightMess{width:auto;height:60px; position:absolute;right:0;top:0}
.rightMess span{width:50px; height:50px; line-height:50px; text-align:center; margin:5px; float:left; background:#f00}

最后JS代码:

<script type="text/javascript">
  var divs = document.getElementsByClassName('item');
  for (var i = 0; i < divs.length; i++) {
    var lastW = divs[i].children[1].offsetWidth;
    divs[i].children[0].style.marginRight=lastW+"px"
  }
</script>

最终效果图:

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# js获取元素宽度  # javascript获取隐藏元素(display:none)的高度和宽度的方法  # js获取浏览器高度 窗口高度 元素尺寸 偏移属性的方法  # js获取Html元素的实际宽度高度的方法  # js获取页面及个元素高度、宽度的代码  # jquery如何获取元素的滚动条高度等实现代码  # jQuery获取页面及个元素高度、宽度的总结——超实用  # 一个JavaScript获取元素当前高度的实例  # 无法获取隐藏元素宽度和高度的解决方案  # 又是  # 不能用  # 配上  # 相对应  # body  # css  # html 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  Laravel如何使用Blade模板引擎?(完整语法和示例)  Laravel如何创建自定义Facades?(详细步骤)  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  焦点电影公司作品,电影焦点结局是什么?  如何注册花生壳免费域名并搭建个人网站?  java中使用zxing批量生成二维码立牌  Laravel如何记录自定义日志?(Log频道配置)  手机网站制作与建设方案,手机网站如何建设?  googleplay官方入口在哪里_Google Play官方商店快速入口指南  如何在阿里云域名上完成建站全流程?  Laravel如何为API编写文档_Laravel API文档生成与维护方法  如何在橙子建站上传落地页?操作指南详解  中山网站推广排名,中山信息港登录入口?  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  Android 常见的图片加载框架详细介绍  开心动漫网站制作软件下载,十分开心动画为何停播?  制作企业网站建设方案,怎样建设一个公司网站?  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  UC浏览器如何设置启动页 UC浏览器启动页设置方法  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  ,交易猫的商品怎么发布到网站上去?  如何快速登录WAP自助建站平台?  Python结构化数据采集_字段抽取解析【教程】  Swift中swift中的switch 语句  如何在宝塔面板中修改默认建站目录?  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  js实现点击每个li节点,都弹出其文本值及修改  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  Laravel中的Facade(门面)到底是什么原理  Java类加载基本过程详细介绍  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  南京网站制作费用,南京远驱官方网站?  Laravel如何使用Blade组件和插槽?(Component代码示例)  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  个人摄影网站制作流程,摄影爱好者都去什么网站?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何打造高效商业网站?建站目的决定转化率  Laravel如何自定义分页视图?(Pagination示例)  Laravel如何实现用户注册和登录?(Auth脚手架指南)  php结合redis实现高并发下的抢购、秒杀功能的实例  Laravel如何使用withoutEvents方法临时禁用模型事件  香港服务器选型指南:免备案配置与高效建站方案解析