Book Image

Build Your Own Web Framework in Elixir

By : Aditya Iyengar
Book Image

Build Your Own Web Framework in Elixir

By: Aditya Iyengar

Overview of this book

Elixir's functional nature and metaprogramming capabilities make it an ideal language for building web frameworks, with Phoenix being the most ubiquitous framework in the Elixir ecosystem and a popular choice for companies seeking scalable web-based products. With an ever-increasing demand for Elixir engineers, developers can accelerate their careers by learning Elixir and the Phoenix web framework. With Build Your Own Web Framework in Elixir, you’ll start by exploring the fundamental concepts of web development using Elixir. You'll learn how to build a robust web server and create a router to direct incoming requests to the correct controller. Then, you'll learn to dispatch requests to controllers to respond with clean, semantic HTML, and explore the power of Domain-Specific Languages (DSL) and metaprogramming in Elixir. You'll develop a deep understanding of Elixir's unique syntax and semantics, allowing you to optimize your code for performance and maintainability. Finally, you'll discover how to effectively test each component of your application for accuracy and performance. By the end of this book, you'll have a thorough understanding of how Elixir components are implemented within Phoenix, and how to leverage its powerful features to build robust web applications.
Table of Contents (15 chapters)
1
Part 1: Web Server Fundamentals
4
Part 2: Router, Controller, and View
10
Part 3: DSL Design

Passing helper functions to templates

We saw earlier in the chapter how Phoenix allows us to use functions defined in the view module inside the templates. This further allows us to clean up the templates and extract shared/complex logic in the templates, by moving it to the views. In this section, we will learn how we can use the EEx module to pass functions to the HTML templates.

In the previous chapter, we used the first two arguments of EEx.eval_file/3 to pass a file path and list of variable bindings to the template. The third argument of this function is a list of options, one of which is :functions. By using the :functions key, we can pass a list of functions that are accessible to the template at the time of its evaluation. We can use this feature to pass a list of functions defined in the view module to our HTML template.

Now that we know how to pass a list of functions to a template, we just need a way to get a list of all the public functions defined in the view module...