 
  How are our app’s user interface and experience design affected by all the other apps a user encounters each day?
As much as we might love for our websites or applications to be special, unique and one-of-a-kind, the truth is that—for our users—they exist in the context of all the other apps and websites they’ve used before. They may use 20 different applications over the course of their entire day, of which ours is just a blip.
What does that mean for us, in terms of user interface and experience design? In order to fully understand, let’s break down two common UX terms: mental model and cognitive load.
A user’s mental model is the understanding they build and the assumptions they make about their current experience, based on the similar experiences they’ve had up until now.
For example, most websites have a logo in the top left corner that will take the user back to the homepage when clicked. Linked text in a webpage is underlined. Right-clicking will open a contextual action menu. When these things don’t happen—or worse, when something else unexpected happens—it throws us off. Our mental models no longer line up!
By meeting the wider standards of web and application design, we allow our user to carry over everything they’ve learned. Things “just work” because we’re not forcing them to go against the grain and learn something new in order to use our product.
Mental models originally came from the analog equivalent or similar real-world experience of what we were doing digitally (for example, the checkout and shopping cart experience of an online retailer). These days, pretty much everyone has extensive experience working digitally—which means that now, mental models are informed by both real-world experiences and digital experiences. As people use technology over the course of their lives, they pick these things up and integrate them into their high-level understanding of How Things Work.
Mental models also can be (and are) constructed on a product-by-product basis. Maybe we use a specific color system to designate different types of information, or maybe our menus are organized in a certain way. We can build mental models within our own platforms by repeating behaviors and teaching new users. However, this is not recommended if those behaviors will contrast with broader models—like setting a custom keyboard shortcut in our app to use Ctrl + S, which conflicts with the wider standard where that shortcut is used for the save action.
We also need to be careful not to create new mental models that differ between applications in a shared product suite. If we want to create a new standard for App A, we should make that also true in App B and C, if they’re intended to be used together. When that’s not the case, we disrupt our users’ product-level mental models—and make life significantly harder for the users who have to switch back and forth between those linked systems regularly.
More than once now, we’ve mentioned that things will get more challenging when the mental model doesn’t line up—but why does that happen? In this and other situations where the user has to make sense of something new, we’re dealing with a concept called cognitive load.
Cognitive load is the amount of effort and energy that it takes for a user to complete a task. Every new page or interaction pattern will increase cognitive cost for users. They have to pause and take time to figure out a new layout, new contents, what they should be doing, where they can click, etc.
If this gets too high, users will (most often) simply give up or stop—leave the website or close the application. In situations where that’s not a viable option for them (such as a work-related task or filing important personal paperwork), they’ll slow down significantly, get frustrated and generally leave the experience with a bad opinion of the brand. Obviously, this isn’t what we want for our users.
The good news is that there are things we can do to reduce the cognitive load on our users. Here are a few good examples:
 
                  Kathryn Grayson Nanz is a developer advocate at Progress with a passion for React, UI and design and sharing with the community. She started her career as a graphic designer and was told by her Creative Director to never let anyone find out she could code because she’d be stuck doing it forever. She ignored his warning and has never been happier. You can find her writing, blogging, streaming and tweeting about React, design, UI and more. You can find her at @kathryngrayson on Twitter.