offset概述、client系列

本文介绍了JavaScript中关于元素偏移量(offset)和可视区(client)的相关属性和用法,包括offsetWidth、offsetHeight、offsetLeft、offsetTop等,以及如何利用它们实现如模态框拖拽、鼠标在盒子内坐标获取、仿京东放大镜等功能。同时讲解了style属性与offset的区别,并提供了实用案例进行说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.元素偏移量offset系列

1.1 offset概述

offset 就是偏移量,可以用offset相关属性可以动态获得元素的位置(偏移)、大小等。
1、获得元素距离带有定位父元素的位置。
2、获得元素自身的大小(宽度高度)
3、注意:返回的数值都不带单位
在这里插入图片描述

1.2 offset与style的区别

offset:
可以得到任意样式表中的样式值
获得的数值没有单位
offsetWidth包含padding+border+width
offsetWidth等属性是只读属性,只能获取不能赋值。

style:
能得到行内样式表中的样式值
style.width获得的是带单位的字符串
style.width获得不包含padding和border的值
style.width是可读写属性,可以获取也可以赋值。

1.3案例:获取鼠标在盒子内的坐标:

<style>
    div {
        height: 500px;
        background-color: yellowgreen;
        border: 1px solid blueviolet;
        margin-top: 10px;
        margin-left: 10px;
    }
</style>
</head>
<body>
<div></div>
<script>
    let div = document.querySelector('div')
    div.addEventListener('mousemove',function(e){
        let x = e.pageX - this.offsetLeft
        let y = e.pageY - this.offsetTop
        this.innerHTML = 'x:' + x + 'y:' + y
    })
</script>

1.4:案例:模态框拖拽

<div class="login-header"><a id="link" href="javascript:;">点击,弹出登录框</a></div>
<div id="login" class="login">
    <div id="title" class="login-title">登录会员
        <span><a id="closeBtn" href="javascript:void(0);" class="close-login">关闭</a></span>
    </div>
    <div class="login-input-content">
        <div class="login-input">
            <label>用户名:</label>
            <input type="text" placeholder="请输入用户名" name="info[username]" id="username" class="list-input">
        </div>
        <div class="login-input">
            <label>登录密码:</label>
            <input type="password" placeholder="请输入登录密码" name="info[password]" id="password" class="list-input">
        </div>
    </div>
    <div id="loginBtn" class="login-button"><a href="javascript:void(0);" id="login-button-submit">登录会员</a></div>
</div>
<!-- 遮盖层 -->
<div id="bg" class="login-bg"></div>

<script>
    //点击弹出
    let link = document.querySelector('#link')
    let login = document.querySelector('#login')
    let bg = document.querySelector('#bg')
    link.addEventListener('click', function () {
        login.style.display = 'block'
        bg.style.display = 'block'
    })

    //点击关闭
    let closeBtn = document.querySelector('#closeBtn')
    closeBtn.addEventListener('click', function () {
        login.style.display = 'none'
        bg.style.display = 'none'
    })

    //拖动
    let title = document.querySelector('#title')
    title.addEventListener('mousedown', function (e) {
        let x = e.pageX - login.offsetLeft
        let y = e.pageY - login.offsetTop
        document.addEventListener('mousemove', fn)

        function fn(e) {
            login.style.left = (e.pageX - x) + 'px'
            login.style.top = (e.pageY - y) + 'px'
        }
        document.addEventListener('mouseup', function () {
            document.removeEventListener('mousemove', fn)
        })
    })

</script>

1.5 案例:仿京东放大镜:

<script>
    window.addEventListener('load',function(){
        let preview_img = document.querySelector('.preview_img')
        let mask = document.querySelector('.mask')
        let big = document.querySelector('.big')
        preview_img.addEventListener('mousemove',function(){
            mask.style.display = 'block'
            big.style.display = 'block'
        })
        preview_img.addEventListener('mouseout',function(){
            mask.style.display = 'none'
            big.style.display = 'none'
        })
        preview_img.addEventListener('mousemove',function(e){
            //1、鼠标在盒子坐标
            let x = e.pageX - this.offsetLeft
            let y = e.pageY - this.offsetTop

            //2、mask遮挡框的移动距离
            let maskX = x - mask.offsetWidth/2
            let maskY = y - mask.offsetHeight/2

            //3、边界距离
            let maskMax =  preview_img.offsetWidth - mask.offsetWidth

            if(maskX <= 0){
                maskX = 0
            }else if(maskX >= maskMax){
                maskX = maskMax
            }
            
            if(maskY <= 0 ){
                maskY = 0
            }else if(maskY >= maskMax){
                maskY = maskMax
            }
            mask.style.left = maskX + 'px'
            mask.style.top = maskY + 'px'

            let bigImg = document.querySelector('.bigImg')
            let bigImgMax = bigImg.offsetWidth - big.offsetWidth
            let bigImgX = maskX * bigImgMax / maskMax
            let bigImgY = maskY * bigImgMax / maskMax

            bigImg.style.left = -bigImgX + 'px'
            bigImg.style.top = -bigImgY + 'px'
        })

    })
</script>

2 元素可视区client系列

我们使用client系列的相关属性可以获取元素可视区的相关信息,可以动态得到该元素的边框大小、元素大小等。
在这里插入图片描述

### Debezium 与 Kafka 客户端集成 Debezium 和 Kafka 客户端之间的集成为实时捕获和处理数据库变更提供了强大支持。通过这种集成,可以轻松实现从关系型数据库到 Apache Kafka 的高效数据复制。 #### 实现机制概述 Debezium 是一种开源分布式平台,用于捕获数据库更改事件,并将其发送至 Kafka 主题中。它利用了数据库的日志功能来跟踪每一项修改操作(插入、更新或删除),并将这些变化转化为结构化的消息流[^3]。 对于现有的大量历史数据,在初次设置时,Debezium 支持执行快照(snapshot),即一次性读取当前表中的所有记录并发布给目标系统;之后则继续监听新的事务日志条目以获取最新的变动情况。 #### 集成步骤详解 为了使 Debezium 成功连接到 Kafka 并传输捕捉到的变化: 1. **配置 Schema Registry** 确认 `schema-registry` 正常运行,因为这是负责管理 Avro 模式的组件之一。模式注册中心会存储关于每种类型的元信息,确保生产者和消费者能够一致地解析二进制格式的数据[^1]。 2. **部署 Connector** 利用 Kafka Connect API 来加载特定版本的 Debezium 连接器实例。这通常涉及指定源数据库类型及其访问参数等必要选项。例如 MySQL 数据库可能如下所示: ```json { "name": "mysql-inventory-connector", "config": { "connector.class": "io.debezium.connector.mysql.MySqlConnector", "tasks.max": "1", "database.hostname": "db-host.example.com", "database.port": "3306", "database.user": "debezium", "database.password": "dbz", "database.server.id": "184054", "database.include.list": "inventory" } } ``` 3. **编写消费逻辑** 开发应用程序订阅由 Debezium 发布的主题,从中提取所需字段完成业务需求。下面是一个简单的 Java 示例代码片段展示如何创建一个基本的 Kafka Consumer: ```java Properties props = new Properties(); props.put("bootstrap.servers", "localhost:9092"); props.put("group.id", "test-group"); props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer"); props.put("value.deserializer", "io.confluent.kafka.serializers.KafkaAvroDeserializer"); props.put("specific.avro.reader", "true"); KafkaConsumer<String, MyEvent> consumer = new KafkaConsumer<>(props); consumer.subscribe(Collections.singletonList("my-topic")); while (true) { ConsumerRecords<String, MyEvent> records = consumer.poll(Duration.ofMillis(100)); for (ConsumerRecord<String, MyEvent> record : records){ System.out.printf("offset = %d, key = %s, value = %s%n", record.offset(), record.key(), record.value()); } } ``` #### 最佳实践建议 - **性能优化**:调整批处理大小、线程数以及缓存策略等方面来提高吞吐量。 - **错误恢复能力**:设计合理的重试机制应对临时性的网络波动或其他异常状况。 - **安全性考量**:启用 SSL/TLS 加密通信渠道保护敏感资料的安全性。 - **监控运维体系构建**:引入 Prometheus 或 Grafana 等工具持续监测集群健康状态以便及时响应潜在风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

春花.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值