整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

python通过requests和BeautifulSoup获取163网站的div标签内容

码如下:

import requests
from bs4 import BeautifulSoup
import pandas as pd
#下面是请求数据
url="https://www.163.com/" #设置请求网址为搜索网址
response=requests.get(url) #对163网站就行get请求并将请求结果赋值给response
response.encoding="GBK" #设置编码为GBK格式的
html=response.text #获取网页的html源代码并赋值给html
#下面是解析数据
soup=BeautifulSoup(html)
content=soup.findAll('div') #查找所有的div标签内容并赋值给content
print(content) #打印content

代码运行结果如下图所示:

avascript使用document.getElementById操作div

javascript中经常会操作div,大家在网上看到的各种酷炫的前端效果,很多都是通过操作div来实现的,下面通过实例代码和注释来讲解:


在很多web或者app页面中,我们可以看到各种各样的输入框,从外观上看它们可以直观的看做是input元素,但是实际上并非如此。我们可以通过别的标签去模拟input标签的效果,今天我们就来看看如何使用div标签模拟input标签的效果。

div+css

页面效果

这里我们用ofo的主页面作为例子,在点击下面数字的时候,数字的内容会出现在输入框内,这个输入框就是用div模拟实现的。

当然页面内容是静态的,只是一个简单的html,我们来看下实现后的效果。如果感兴趣的可以直接去github上去看看,源码地址:

https://github.com/zhouxiongking/article-pages/tree/master/articles/divToInput

实现效果

显示框

这里我们定义一个显示内容的div来模拟input,其css样式如下。

css样式

:before

我们使用:before伪元素来装载输入的内容,在:before元素中使用content属性来动态的元素的属性值。

使用:before伪元素

闪烁动作

在input标签中,如果input元素获取焦点后,在input元素内会有光标在闪烁,这个效果我们可以通过:after伪元素来实现。

我们会用到动画animation的知识,首先定义一个动画效果,利用opacity属性来控制显示与不显示,从而造成闪烁效果。

定义闪烁动作

然后在:after伪元素中使用。

:after伪元素

Javascript控制输入

在设置好div效果后,需要在点击下面的数字时,将值显示在div中,这就需要用到Javascript去控制。

首先获取页面上所有存在动作的元素。

获取元素

然后给数字和删除元素分别添加对应的事件。

元素绑定事件

绑定事件后,在点击数字时会将值动态的显示在div中,在删除时也会相应删掉最后一个添加的元素值。

页面设计

对于整个页面的设计,采用了header,div和footer的布局。

header和div的html部分代码如下。

header与div

相应的footer部分代码如下,其主要采用的是table布局,相对简单实用。

footer部分

至此,整个页面的实现就讲解完毕了,中间有很多的css样式部分我并没有放出来,感兴趣的可以自行去github上clone下来看看。

总结

今天这篇文章主要以ofo主页面实现来讲解了一下如何使用div来模拟input的效果,你有收获吗