html 布局 id class,不使用class和id进行网页布局的方法

结合了富有新的语义化标记的HTML5,CSS3为web设计师们的网页提供了神一般的力量。有了HTML5的能量,我们将得到更多的对文档代码的控制权,有了CSS3的能量,我们的控制权将趋于无穷大!

即使没有那些高级的CSS选择器,我们仍然可以通过强大的HTML5条调用不同的容器而不劳驾class和id这类属性。像以往的DIV布局,我们在css中可能要这样调用:

div#news {}

div.section {}

div.article {}

div.header {}

div.content {}

div.footer {}

div.aside {}

我们再来看看基于HTML5的实例:

section {}

article {}

header {}

footer {}

aside {}

这是个进步,但仍有一些问题需要解决。在

实例中,我们需要通过class或id属性来调用页面中的元素。这种逻辑将允许我们将样式应用到文档中的任何一个元素上,无论是整体还是个体。例如在
实例中,.section 和 .content元素很容易定位。但是在HTML5实例中,实际文档中会有很多个section元素。其实我们可以添加一些特定的属性选择器来调用那些不同的section元素,不过谢天谢地,我没现在可以用少量的高级CSS选择器来定位不同的section元素。

下面让我们来看看如何在不使用class和id的情况下定位HTML5页面元素的一个实例,我们可以使用三种CSS选择器来定位和辨别实例中的元素。如下:

后代选择器:[CSS 2.1]: E F

兄弟选择器:[CSS 2.1]: E + F

子元素选择器:[CSS 2.1]: E > F

下面让我们来看看如何不使用class和id而完成对文档中的那些section元素的定位吧:

定位最外层的元素

考虑到我们的例子并不是一套完整的HTML5代码,所以我们假定在

元素下有个元素与元素是兄弟元素。这样的话,我们就可以向下面代码那样定位最外层的了:

body nav+section {}

定位下一个元素

作为最外层元素下的唯一直属子集元素,这个元素也许可以这样定位:

section>section {}

定位元素

可以定位元素的方法有很多,不过最简单的方法当然就是后代选择器了:

section section article {}

定位、和元素

这三个元素分别在两个地方都出现过,一是在元素中出现,另一是在元素中出现。这种差别能让我们轻松定位每个元素。

article header {}

article section {}

article footer {}

或者一起定义:

section section header {}

section section section {}

section section footer {}

到目前为止,我们已经使用CSS2.1选择器排除掉了所有的class和id。那么我们为什么还需要使用CSS3呢?我很高兴你能这么问…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用PreferenceViewHolder的id需要进行以下步骤来设置布局: 1. 在res/layout目录下创建一个xml文件,命名为preference.xml,用于定义Preference布局的样式和控件。 2. 在xml文件中定义Preference布局所需的控件,例如TextView,CheckBox等,并为每个控件设置一个唯一的id。 3. 在PreferenceFragment或PreferenceActivity的onCreate方法中,通过调用addPreferencesFromResource方法将preference.xml文件加载到PreferenceScreen中。 4. 在PreferenceFragment或PreferenceActivity的onBindViewHolder方法中,调用PreferenceViewHolder的findViewById方法获取每个控件的id,并将其设置给对应的控件。 以下是一个示例代码: preference.xml文件: ``` <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> <PreferenceCategory android:title="Category Title"> <CheckBoxPreference android:id="@+id/checkbox_preference" android:key="checkbox_preference" android:title="Checkbox Preference" android:summary="This is a checkbox preference" /> <EditTextPreference android:id="@+id/edittext_preference" android:key="edittext_preference" android:title="EditText Preference" android:summary="This is an edit text preference" /> </PreferenceCategory> </PreferenceScreen> ``` PreferenceFragment的onCreate方法: ``` public class MyPreferenceFragment extends PreferenceFragmentCompat { @Override public void onCreatePreferences(Bundle savedInstanceState, String rootKey) { addPreferencesFromResource(R.xml.preference); } @Override public void onBindViewHolder(PreferenceViewHolder holder, int position) { super.onBindViewHolder(holder, position); CheckBoxPreference checkboxPreference = (CheckBoxPreference) holder.findViewById(R.id.checkbox_preference); EditTextPreference edittextPreference = (EditTextPreference) holder.findViewById(R.id.edittext_preference); // Do something with the preferences... } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值