整合营销服务商

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

免费咨询热线:

8 种现代 JavaScript 响应式模式

应性本质上是关于系统如何对数据变化作出反应,有不同类型的响应性。然而,在这篇文章中,我们关注的是响应性,即响应数据变化而采取行动。

作为一名前端开发者,Pavel Pogosov 每天都要面对这个问题。因为浏览器本身是一个完全异步的环境。现代 Web 界面必须快速响应用户的操作,这包括更新 UI、发送网络请求、管理导航和执行各种其他任务。

尽管人们常常将响应性与框架联系在一起,Pavel Pogosov 认为通过纯 JavaScript 实现响应性可以学到很多。所以,我们将自己编写一些模式代码,并研究一些基于响应性的原生浏览器 API。

目录

  • PubSub(发布-订阅模式)
  • 自定义事件作为浏览器版本的 PubSub
  • 自定义事件目标
  • 观察者模式
  • 使用 Proxy 的响应式属性
  • 单个对象属性和响应性
  • 使用 MutationObserver 的响应式 HTML 属性
  • 使用 IntersectionObserver 的响应式滚动

1. PubSub(发布-订阅模式)

class PubSub {
  constructor() {
    this.subscribers = {};
  }

  subscribe(event, callback) {
    if (!this.subscribers[event]) {
      this.subscribers[event] = [];
    }

    this.subscribers[event].push(callback);
  }

  // 向特定事件的所有订阅者发布消息
  publish(event, data) {
    if (this.subscribers[event]) {
      this.subscribers[event].forEach((callback) => {
        callback(data);
      });
    }
  }
}

const pubsub = new PubSub();

pubsub.subscribe('news', (message) => {
  console.log(`订阅者1收到了新闻:${message}`);
});

pubsub.subscribe('news', (message) => {
  console.log(`订阅者2收到了新闻:${message}`);
});

// 向 'news' 事件发布消息
pubsub.publish('news', '最新头条新闻:...');

// 控制台日志输出:
// 订阅者1收到了新闻:最新头条新闻:...
// 订阅者2收到了新闻:最新头条新闻:...

一个常见的使用示例是 Redux。这款流行的状态管理库基于这种模式(或更具体地说,是 Flux 架构)。在 Redux 的上下文中,工作机制相当简单:

发布者:store 充当发布者。当一个 action 被派发时,store 会通知所有订阅的组件状态的变化。 订阅者:应用程序中的 UI 组件是订阅者。它们订阅 Redux store 并在状态变化时接收更新。

自定义事件作为浏览器版本的 PubSub

浏览器通过 CustomEvent 类和 dispatchEvent 方法提供了一个用于触发和订阅自定义事件的 API。后者不仅能让我们触发事件,还能附加任何想要的数据。

const customEvent = new CustomEvent('customEvent', {
  detail: '自定义事件数据', // 将所需数据附加到事件
});

const element = document.getElementById('.element-to-trigger-events');

element.addEventListener('customEvent', (event) => {
  console.log(`订阅者1收到了自定义事件:${event.detail}`);
});

element.addEventListener('customEvent', (event) => {
  console.log(`订阅者2收到了自定义事件:${event.detail}`);
});

// 触发自定义事件
element.dispatchEvent(customEvent);

// 控制台日志输出:
// 订阅者1收到了自定义事件:自定义事件数据
// 订阅者2收到了自定义事件:自定义事件数据

自定义事件目标

如果你不想在全局 window 对象上分派事件,可以创建你自己的事件目标。

通过扩展原生 EventTarget 类,你可以向其新实例分派事件。这确保你的事件仅在新类本身上触发,避免了全局传播。此外,你可以直接将处理程序附加到这个特定实例上。

class CustomEventTarget extends EventTarget {
  constructor() {
    super();
  }

  // 触发自定义事件的自定义方法
  triggerCustomEvent(eventName, eventData) {
    const event = new CustomEvent(eventName, { detail: eventData });
    this.dispatchEvent(event);
  }
}

const customTarget = new CustomEventTarget();

// 向自定义事件目标添加事件监听器
customTarget.addEventListener('customEvent', (event) => {
  console.log(`自定义事件收到了数据:${event.detail}`);
});

// 触发自定义事件
customTarget.triggerCustomEvent('customEvent', '你好,自定义事件!');

// 控制台日志输出:
// 自定义事件收到了数据:你好,自定义事件!

观察者模式

观察者模式与 PubSub 非常相似。你订阅 Subject,然后它通知其订阅者(观察者)关于变化,使他们能够做出相应的反应。这种模式在构建解耦和灵活的架构中发挥了重要作用。

class Subject {
  constructor() {
    this.observers = [];
  }

  addObserver(observer) {
    this.observers.push(observer);
  }

  // 从列表中移除观察者
  removeObserver(observer) {
    const index = this.observers.indexOf(observer);

    if (index !== -1) {
      this.observers.splice(index, 1);
    }
  }

  // 通知所有观察者关于变化
  notify() {
    this.observers.forEach((observer) => {
      observer.update();
    });
  }
}

class Observer {
  constructor(name) {
    this.name = name;
  }

  // 通知时调用的更新方法
  update() {
    console.log(`${this.name} 收到了更新。`);
  }
}

const subject = new Subject();
const observer1 = new Observer('观察者1');
const observer2 = new Observer('观察者2');

// 将观察者添加到主体
subject.addObserver(observer1);
subject.addObserver(observer2);

// 通知观察者关于变化
subject.notify();

// 控制台日志输出:
// 观察者1 收到了更新。
// 观察者2 收到了更新。

使用 Proxy 的响应式属性

如果你想对对象的变化做出反应,Proxy 是一个好方法。它让我们在设置或获取对象字段的值时实现响应性。

const person = {
  name: 'Pavel',
  age: 22,
};

const reactivePerson = new Proxy(person, {
  // 拦截设置操作
  set(target, key, value) {
    console.log(`将 ${key} 设置为 ${value}`);
    target[key] = value;

    // 表示设置值是否成功
    return true;
  },
  // 拦截获取操作
  get(target, key) {
    console.log(`获取 ${key}`);

    return target[key];
  },
});

reactivePerson.name = 'Sergei'; // 将 name 设置为 Sergei
console.log(reactivePerson.name); // 获取 name: Sergei

reactivePerson.age = 23; // 将 age 设置为 23
console.log(reactivePerson.age); // 获取 age: 23

单个对象属性和响应性

如果你不需要跟踪对象中的所有字段,可以使用 Object.defineProperty 或一组 Object.defineProperties 来选择特定的一个或几个。

const person = {
  _originalName: 'Pavel', // 私有属性
}

Object.defineProperty(person, 'name', {
  get() {
    console.log('获取属性 name')
    return this._originalName
  },
  set(value) {
    console.log(`将属性 name 设置为值 ${value}`)
    this._originalName = value
  },
})

console.log(person.name) // '获取属性 name' 和 'Pavel'
person.name = 'Sergei' // 将属性 name 设置为值 Sergei

使用 MutationObserver 的响应式 HTML 属性

在 DOM 中实现响应性的一种方法是使用 MutationObserver。其 API 允许我们观察目标元素及其子元素的属性变化和文本内容变化。

function handleMutations(mutationsList, observer) {
  mutationsList.forEach((mutation) => {
    // 观察到的元素的一个属性发生了变化
    if (mutation.type === 'attributes') {
      console.log(`属性 '${mutation.attributeName}' 更改为 '${mutation.target.getAttribute(mutation.attributeName)}'`);
    }
  });
}

const observer = new MutationObserver(handleMutations);
const targetElement = document.querySelector('.element-to-observe');

// 开始观察目标元素
observer.observe(targetElement, { attributes: true });

使用 IntersectionObserver 的响应式滚动

IntersectionObserver API 允许对目标元素与另一个元素或视口区域的交集做出反应。

function handleIntersection(entries, observer) {
  entries.forEach((entry) => {
    // 目标元素在视口中
    if (entry.isIntersecting) {
      entry.target.classList.add('visible');
    } else {
      entry.target.classList.remove('visible');
    }
  });
}

const observer = new IntersectionObserver(handleIntersection);
const targetElement = document.querySelector('.element-to-observe');

// 开始观察目标元素
observer.observe(targetElement);

感谢阅读!

这个适合初学者的指南中,你将学习如何创建一个响应式电子邮件模板。你将跟随逐步说明以及代码片段设计一个在任何设备上都看起来很棒的电子邮件模板。

这个项目非常适合渴望掌握电子邮件设计基础的新手!

(本文视频讲解:java567.com)

何让你的网站在其出现的任何设备和屏幕尺寸上能够完美的呈现?响应式设计完美的解决了这一难题,作为现在的网页设计师都应该了解响应式网页设计的原则。而对于刚步入网页设计的新手设计师,如果你还不了解什么是响应式设计?如何制作响应式页面?这篇文章为大家提供了12个基础的响应式网页设计的教程,结尾还附上了个人最喜欢的3款响应式网页设计的工具, 轻松带你入门。

1. What is Responsive Web Design?

https://smallbiztrends.com/2013/05/what-is-responsive-web-design.html

随着智能手机,平板电脑以及其他移动设备的增长,越来越多人使用小屏幕来查看和阅读网页信息。响应式网页设计完美的满足了这一点,它使得用户能够在各种设备下查看网页,并且保持良好的网页可读性。并且, 在2018年4月Google宣布了移动优先索引的原则,所以响应式网页设计已经是一个必须。这篇文章是一篇新手文章,对于还不懂什么是响应式设计的设计师一个很好的开篇解释。

2. Responsive Web Design Tutorial and Explanation

https://www.youtube.com/watch?v=BIz02qY5BRA

如果你对响应式网页设计的概念完全陌生,又不想看冗长的文章,那么这个视频绝对是你的不二之选。本视频解释了什么是响应式网页设计,结合具体的例子介绍让你更加了解,当然最重要的是视频中详细的介绍如何通过写代码去设计一个响应式网页布局。

3. Responsive Web Design with HTML&CSS

https://learn.shayhowe.com/advanced-html-css/responsive-web-design/

本教程解释了响应式设计和自适应设计的区别,并且详细介绍如何使用HTML和CSS写响应式网页,以及介绍媒体查询和mobile-first的使用。

4. Responsive Data Table Roundup

https://css-tricks.com/responsive-data-table-roundup/

数据表是HTML的重要组成部分,虽然它们过去经常被用于布局,但现在它们主要是用于标记数据。本文具体介绍了如何制作响应式数据表,文章包含多个demo可供参考。

5. Bootstrap Responsive Web Design Tutorial For Beginners

https://www.udemy.com/bootstrap-responsive-web-design-tutorial-for-beginners/

Bootstrap是最受欢迎的HTML,CSS和JS框架之一,用于在Web上开发响应式,移动友好的项目。本教程帮组你如何使用bootstrap框架来开发响应式网页,你可以从中学到:

使用Twitter bootstrap制作响应式网页

了解bootstrap组件的使用

学习要求:

对Html有基本理解

希望扩展知识的Web Masters和Web开发人员

价格:.99

6. How to Make Responsive WordPress Websites (With Themes)

https://business.tutsplus.com/articles/how-to-make-responsive-websites--cms-29942

在构建网站时,使用响应式设计不再只是一种选择,它是必须。无论你的用户使用哪种设备进行查看和浏览网页内容,响应式网站设计都能让你的网站看起来很棒。对于许多企业来说,WordPress是个很好的选择,鉴于它的灵活性和易于使用。从本教程中,你可以学习到如何使用响应式WordPress模板来创建你的网站以及如何选择响应式WordPress主题。

7. Responsive Web Design - Introduction

https://www.w3schools.com/css/css_rwd_intro.asp

W3schools是个代码学习的网站,你可以在这里找到你想要学习的一切代码知识。当然这里提供的响应式网页设计的教程是非常全面且具体的。你可以学习到:

RWD视口

RWD网格视图

RWD媒体查询

RWD图像

RWD视频

RWD框架

RWD模板

8. 10 Best Free Responsive HTML5 Web Templates in 2018

https://www.mockplus.com/blog/post/free-responsive-html5-web-design-templates

本文为制作HTML响应式设计的设计师提供了最佳的10个模板,让你能够轻松应用。

9. The Ultimate Responsive Web Design Tutorials for Beginners

https://www.youtube.com/watch?v=YBK_1WrM294

Chris Converse在本教程中分享自己的专业技术,帮助初学者如何建立一个响应式网站。Chris还展示了如何使用CSS加载图像,重新定位导航栏以便在移动设备上更好地查看,以及如何通过提供多个版本的banner图形和其他图像来缩短小屏幕的下载时间。另外,你还能了解如何使用CSS 媒体查询替换Retina显示器的高分辨率版本的图形。这篇教程可以说是最终极的响应式网页设计教程。

10. Build An HTML5 Website With A Responsive Layout

https://www.youtube.com/watch?v=Wm6CUkswsNw

这个视频教程对于新手来说是一个很好的学习响应式网页设计的教程,教大家如何创建一个实例的HTML5的响应式网页。视频还将谈论如何使用HTML语义化标签,诸如,页面和页脚。

11. Responsive Web Design Tutorial

https://www.youtube.com/watch?v=3tLb3i7GB38&list=PL4cUxeGkcC9g9Vh9MAA-XKnfJsWZnPZFw

本系列教程涵盖了12个学习视频,可以说是一个很完整的响应式网页设计的教程。从介绍什么是响应式网页设计到如何创建响应式网页,你可以学习到你想要了解响应式网页的一切知识点。

12. The pro's guide to responsive web design

https://www.creativebloq.com/rwd/pros-guide-responsive-web-design-71515692

我们都知道响应式设计对于每一个网站都是必须的,但在实践中,我们也知道了它并不是那么容易实现的技术。本文集合了许多优秀的网页设计师的建议,帮助大家如何从基础知识上升到高层次的响应式网页设计。

响应式网页设计的工具

Bootstrap

Bootstrap是美国Twitter公司的设计师Mark Otto和Jacob Thornton合作基于HTML、CSS、JavaScript 开发的简洁、直观、强悍的前端开发框架,使得 Web 开发更加快捷。它也是最受欢迎的HTML、CSS 和 JS 框架,用于开发响应式布局、移动设备优先的web项目。

Mockplus

Mockplus是一款在线协作设计工具,允许你创建交互式网页和原型。这个工具很强大,可以快速的输出交互网页,为用户提供包含通用设计的工具包和组件库。

Responsinator

这是一个响应式网页测试的工具,只要输入网站的URL就能轻松的知道你的网站是否友好。并且,你还可以直接与页面进行交互,点击页面链接。

总结

响应式布局可以为不同终端的用户提供更加舒适的界面和更好的用户体验,而且随着目前各种移动设备的普及,用“大势所趋”来形容也不为过。新手网页设计师必须掌握这一技术来实现更好的网站用户体验,以上12个教程以及3个响应式网页设计工具希望可以轻松带你入门。