点击相对应的块

<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    ul,li{
        padding: 0;
        margin: 0;
        list-style: none;
    }
    ul{
        width: 300px;
        height: 300px;
    }
    li{
        width: 100px;
        height: 100px;
        border: 1px solid #000;
        box-sizing: border-box;
        /* box-sizing: 设置当前width、height包含的内容有哪些
            border-box: border + width
            content-box: width
         */
        float: left;
        text-align: center;
        line-height: 100px;
    }
    div{
        width: 100px;
        height: 100px;
        background: red;
        margin-left: 10px;
        float: left;
        display: none;
    }
</style>
<body>
    <ul>
        <li>001</li>
        <li>002</li>
        <li>003</li>
        <li>004</li>
        <li>005</li>
        <li>006</li>
        <li>007</li>
        <li>008</li>
        <li>009</li>
    </ul>

    <div>01</div>
    <div>02</div>
    <div>03</div>
    <div>04</div>
    <div>05</div>
    <div>06</div>
    <div>07</div>
    <div>08</div>
    <div>09</div>

    <script>
        // for循环在页面加载的一瞬间执行完成, 当前i已经变成了循环结束的的条件
        // 点击每一个li, 让当前的li背景色变红
        var lis = document.getElementsByTagName('li');
        var divs = document.getElementsByTagName('div');
        // 每一个添加事件
        for(var i = 0; i < lis.length; i++){
            console.log(i);
            // 把自己的下标作为标签的一个属性值存储在自定义属性上 ---> 自定义索引
            // 标签.属性名 = 下标;
            
            lis[i].index = i;
            lis[i].onclick = function(){
                // console.log(lis, i);
                // for循环嵌套的事件中得不到正确的下标i
                // 改变li的背景色
                console.log(this.index);
                // lis[i].style.background = 'red';
                this.style.background = 'red';

                divs[this.index].style.display = 'block';
            }
        }
    </script>
</body>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: LabVIEW是一款强大的可视化编程软件,在与西门子PLC进行通讯方面也有很好的支持。要实现LabVIEW直接读取西门子PLC的DB数据,可以按照以下步骤进行操作: 1. 首先,确保已经正确安装了LabVIEW软件,并且已经下载并安装了与西门子PLC通讯所需的驱动程序。 2. 打开LabVIEW软件,创建一个新的VI(Virtual Instrument)。 3. 在VI的界面上,点击右键,选择“Instrument I/O”菜单,然后选择“Industrial Communication”子菜单,再选择“OPC”. 4. 接下来,会弹出“OPC Client Properties”窗口。在窗口中,点击“Server List”按钮,选择PLC所连接的OPC服务器。 5. 在“OPC Item Creation”标签页中,点击“Add”按钮,然后选择要读取的DB,并指定需要读取的数据项或变量。 6. 设置好读取的数据项后,点击“OK”按钮,然后在VI界面上创建一个读取数据的循环。 7. 在循环中,使用“OPC Read”函数来读取已经设置好的数据项。 8. 通过连接数据项和需要展示读取结果的指示器,可以实时显示从PLC读取的DB数据。 9. 最后,运行已经创建好的VI,LabVIEW将会直接读取西门子PLC的DB数据,并在界面上实时显示出来。 通过以上步骤,就可以实现LabVIEW直接读取西门子PLC的DB数据。 ### 回答2: LabVIEW是一种图形化编程环境,可以与各种硬件设备进行通信,包括西门子PLC。要直接读取西门子PLC的DB数据,可以使用LabVIEW提供的相关模和库。 首先,需要将西门子PLC与计算机连接。可以使用RS232、RS485、以太网等通信接口,将PLC与计算机相连。 在LabVIEW中,可以使用NI的数据采集卡、以太网模或串口通信模等适配器将计算机与PLC连接起来。 然后,在LabVIEW中创建一个新的VI(Virtual Instrument),用于读取PLC的DB数据。 在VI中,可以使用LabVIEW提供的Modbus或OPC等通信协议来与PLC通信。根据具体情况选择适合的协议。 通过协议,可以建立与PLC之间的连接,并读取PLC的DB数据。可以指定DB的地址、长度和数据类型等参数。 使用LabVIEW的图形化编程环境,可以轻松配置和调整读取DB的设置。可以将读取到的数据显示在LabVIEW界面上,或者进行后续的数据处理和分析。 最后,可以将LabVIEW程序进行编译,生成可执行文件,从而实现与西门子PLC直接交互并读取DB数据的功能。 总之,通过LabVIEW提供的模和库,以及相关通信协议的支持,我们可以方便地实现直接读取西门子PLC的DB数据的功能。 ### 回答3: LabVIEW可以直接读取西门子PLC的DB(数据)数据,通过与PLC之间建立通信连接来实现。以下是通过LabVIEW读取西门子PLC DB数据的步骤: 1. 首先,确保你已经安装了适当的驱动程序和通信库,以便LabVIEW与西门子PLC进行通信。常用的驱动程序包括LabVIEW DSC模、OPC(OLE for Process Control)服务器等。 2. 在LabVIEW中,创建一个新的VI(虚拟仪器)。在“函数面板”上,选择“Instrument I/O”选项,然后选择适当的驱动程序来建立与PLC的通信连接。 3. 在VI的“图”中,使用适当的函数来读取DB数据。例如,可以使用“TCP Open Connection”函数打开与PLC的TCP/IP连接。然后,使用“TCP Write”函数将请求发送到PLC,以请求特定的DB数据。最后,使用“TCP Read”函数读取PLC返回的数据,并将其解析为LabVIEW可识别的格式。 4. 根据PLC的数据结构和DB的布局,在LabVIEW中定义与DB相对的数据结构。可以使用LabVIEW中的数据类型和结构数组来表示DB的不同部分和变量。 5. 在读取DB数据之前,确保已正确配置PLC的通信设置。这包括正确的IP地址、端口号和其他通信参数。错误的通信设置可能导致读取失败。 6. 运行LabVIEW VI,它将与西门子PLC建立通信连接,并读取DB数据。你可以验证读取的数据是否正确,并在必要时进行进一步的处理或显示。 通过以上步骤,LabVIEW可以直接读取西门子PLC的DB数据。这种方法可以使用户通过编程方式实时监测和控制PLC,并将数据与LabVIEW的其他功能集成在一起。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值