Programming Tips πŸ’‘
51.6K subscribers
67 photos
10 videos
30 files
354 links
Programming & AI:
Tips πŸ’‘
Articles πŸ“•
Resources πŸ‘Ύ
Design Patterns πŸ’Ž
Software Principles βœ…

πŸ‡³πŸ‡± Contact: @MoienTajik

🎯 Buy ads: https://telega.io/c/ProgrammingTip
Download Telegram
Pug 🐢

Pug is a high-performance template engine heavily influenced by Haml and implemented with JavaScript for Node.js and browsers. βœ…

Pug is a clean, whitespace sensitive syntax for writing html. 🌐

Here is a simple example πŸ’Ž :
doctype html
html(lang="en")
head
title= pageTitle
script(type='text/javascript').
if (foo) bar(1 + 5)
body
h1 Pug - node template engine
#container.col
if youAreUsingPug
p You are amazing
else
p Get on it!
p.
Pug is a terse and simple templating language with a
strong focus on performance and powerful features.


Becomes :
<!DOCTYPE html>
<html lang="en">
<head>
<title>Pug</title>
<script type="text/javascript">
if (foo) bar(1 + 5)
</script>
</head>
<body>
<h1>Pug - node template engine</h1>
<div id="container" class="col">
<p>You are amazing</p>
<p>Pug is a terse and simple templating language with a strong focus on performance and powerful features.</p>
</div>
</body>
</html>


πŸ”ΈπŸ”ΉπŸ”ΈπŸ”Ή

βž– Implementations in other languages πŸ‘Ύ
Ports with very close syntax, adapted to other languages :
β€’ PHP
β€’ Java
β€’ Python
β€’ Ruby
β€’ C# (ASP.NET Core)

https://t.me/pgimg/108

[ Github ] : http://bit.do/pugv

γ€°γ€°γ€°γ€°γ€°γ€°
#ViewEngine #TemplateEngine
@ProgrammingTip
Using Google reCAPTCHA in ASP.NET MVC πŸ‘Ύ

reCAPTCHA is a free service that protects your website from spam and abuse. βœ…

reCAPTCHA uses an advanced risk analysis engine and adaptive Captchas to keep automated software from engaging in abusive activities on your site. 🚫

It does this while letting your valid users pass through with ease. πŸ’Ž

This article shows how to integrate reCAPTCHA version 2.0 into an ASP.NET MVC website in clean way. ⚑️


Article Author : @MoienTJ

https://t.me/pgimg/109

[ Article ] : bit.do/recaptcha

γ€°γ€°γ€°γ€°γ€°γ€°
#reCaptcha #AspMvc
@ProgrammingTip
Securing ASP.NET Core 2.0 Applications with JWTs + Auth0 πŸ”‘

JSON Web Tokens, often shortened with JWTs, are gathering more and more popularity in the Web environment. 🌐

It is an open standard that allows transmitting data between parties as a JSON object in a compact and secure way. πŸ”

They are usually used in authentication and information exchange scenarios, since the data transmitted between a source and a target are digitally signed so that they can be easily verified and trusted. βœ…

Let's take a look at how to set up a ASP.NET Core 2 application with JWT support by creating a Web API application. ✨

https://t.me/pgimg/110

[ Article ] : http://bit.do/auth0

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core #JWT
@ProgrammingTip
A Pattern is a solution to a problem in a context. βœ…

We're going to step throught each of these parts, context, problem and solution ✨ :

The context is the situation in which the pattern applies. This should be a recurring situation. πŸ‘¨πŸ»β€πŸ”§

The problem refers to the goal you are trying acheive in this context, but it also refers to any constraints that occur in the context. πŸ†

The solution is what you're after : a general design that anyone can apply which resolves the goal and set of constraints. πŸ…

βž– Example
Problem: How do I get to work on time❓

Context: I've locked my keys in the car. πŸ—

Solution: Break the window, get in the car, start the engine and drive to work. πŸš—


"If you find yourself in a context with a problem that has a goal that is affected by a set of constraints, then you can apply a design that resolves the goal and constraints and leads to a solution."


γ€°γ€°γ€°γ€°γ€°γ€°
#DesignPatterns #Tips
@ProgrammingTip
If you don't need it now, don't do it now❗️

Design Patterns are powerful, and it's easy to see all kinds of ways they can be used in your current designs.⚑️

Developers naturally love to create beautiful architectures that are ready to take on change from any direction.πŸ’™

If you have a practical need to support change in a design today, go ahead and employ a pattern it handle that change. βœ…

However, if the reason is only hypothetical, don't add the pattern, it is only going to add complexity to your system, and you might never need it. ❌

γ€°γ€°γ€°γ€°γ€°γ€°
#DesignPatterns #Tips
@ProgrammingTip
14 Latest and Best 404 Error Page Designs for Webs/Mobile Apps ✨

A 404 error page, which often serves to alert web/app visitors that the page they are trying to reach does not exist, is often regarded as one of the most possible elements to lose users/visitors with boring and dull logging-in/out/loading/leading pages in a web/app. πŸ™„

However, that does not mean such error pages will be a nightmare in all cases. ❌

Actually, a creative, cool, interesting or informative 404 error page can not only lead customers to other parts of your websites/apps smoothly, but also reduce customer frustration and let them stay on the site/app much longer. πŸ’Ž

Let’s keep reading this article and enjoy 14 latest and best 404 error page designs to get inspiration and learn how to make a beautiful, interesting and attractive 404 error not found page design. ⚑️

https://t.me/pgimg/111

[ Article ] : https://goo.gl/A5mJjx

γ€°γ€°γ€°γ€°γ€°γ€°
#Design #UI #UX
@ProgrammingTip
ASP.NET Core 2 – Global Model Validation ⚠️

We use a lot of repetitive code in our actions. ♻️

Inside of our controller actions we usually check if the model is valid by using ModelState property available on MVC’s base controller class :

if (!ModelState.IsValid)  
return BadRequest(ModelState);


The bad thing about is that we repeat this piece of code throughout a lot of our actions. ❌

How we can make it better❓

This article shows you how to validate ModelState with a global filter. πŸ’Ž

https://t.me/pgimg/112

[ Article ] : bit.do/mval

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core #Validation
@ProgrammingTip
Controller Lookup & Default Controller Factory 🏭

As the name, the Controller factory is the component responsible for searching and creating controllers.πŸ‘·

Like many other components, ASP.NET MVC has a built-in factory named DefaultControllerFactory that's pretty much sufficient in most cases. πŸ’Ž

Searching a controller is a perform intensive job and the DefaultControllerFactory does some efficient caching mechanism to avoid looking for controllers every time when there is a need. βœ…

In this article we are going to explore how the DefaultControllerFactory searches for a controller and what kind of strategies it uses to do the process efficiently. ⚑️

https://t.me/pgimg/113

[ Article ] : bit.do/cfac

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Controller #Depth
@ProgrammingTip
Render Action & Render Partial.png
1 MB
Nancy wants to display the logged-in users in a partial view. πŸ‘€

She got confused whether to use RenderAction or RenderPartial.🧐

Mark clarifies her when to use what. βœ…

γ€°γ€°γ€°γ€°γ€°
#AspMvc
@ProgrammingTip
Principle of Least Surprise 😳

Principle Statement :

In interface design, always do the least surprising thing. 😨

Description :

Never surprise the user. ❌

An interface should behave exactly as the user thinks it behaves. βœ…

What surprises the user depends on the kind of interface and the type of user. πŸ–₯

The central idea of PLS is to think about how the user would want to use the interface. 🀳🏻

Principle of least astonishment is when you, as an API designer, prevent your users from saying WAT. 😱

πŸ”ΈπŸ”ΉπŸ”ΈπŸ”Ή

Examples :

1️⃣ Consider an elevator with a button next to it that says "call". ☎️

When you press the button, the payphone phone rings (rather than calling the elevator to that floor). ❌

The correct design would be to put the call button next to the phone rather than the elevator. β›“


2️⃣ Think of a web page that has popup window that shows a windows style error with an 'ok' button on it. πŸ†—

People click the 'ok' button thinking it is for the operating system and instead go to another web page. 🌐

This astonishes the user. 😦


3️⃣ The name of a function should reflect what it does. Otherwise, a user of the function will be unpleasantly surprised❗️

Bad :
int multiply(int a, int b)
{
return a + b;
}


Better :
int multiply(int a, int b)
{
return a * b;
}


πŸ”ΉπŸ”ΈπŸ”ΉπŸ”Έ

When it comes to an API ... πŸ‘Ύ

β€’ Think about a toString() method that instead of printing out the fields returns back "to be implemented". πŸ€₯

β€’ An equals() method that works on hidden information. πŸ‘

β€’ Sometimes people try to implement a sorted list class by changing the add method to call sort() on the array afterwards. πŸ—‚

This astonishing because the add method is supposed to append to the list. πŸ—³

This is especially astonishing when one gets back a List object with no knowledge that somewhere deep inside, someone violated the interface contract. πŸ€”

Having a method that does one distinct thing contributes to reduction of astonishment. βœ…

https://t.me/pgimg/115

γ€°γ€°γ€°γ€°γ€°γ€°
#Principle #PLS
@ProgrammingTip
Nivo ✨

Provides supercharged React components to easily build dataviz apps, it's built on top of d3. βš›οΈ

Several libraries already exist for React d3 integration, but just a few provide server side rendering ability and fully declarative charts. πŸ’Ž

Features :
πŸ”Έ Highly customizable
πŸ”Ή Motion/transitions
πŸ”Έ Component playground
πŸ”Ή Exhaustive documentation
πŸ”Έ Isomorphic rendering
πŸ”Ή SVG charts
πŸ”Έ HTML charts
πŸ”Ή Canvas charts
πŸ”Έ Server side rendering API
πŸ”Ή Gradients
πŸ”Έ Responsive charts

https://t.me/pgimg/116

[ Source ] : github.com/plouc/nivo

[ Document & Website ] : nivo.rocks

γ€°γ€°γ€°γ€°γ€°γ€°
#React #Chart #Calendar
#Treemap #JavaScript

@ProgrammingTip
Use DbContextPooling to Improve the Performance : .NET Core 2.1 Feature πŸ’Ž

If you are familiar with .NET Core, then you might be knowing AddDbContext method. 🧐

This method is used to inject dependency of DbContext into your controller and it should be written in the Startup.cs class. πŸ’‰

So in case of AddDbContext, a new instance will be created for each request and would get disposed once the work is done. ♻️

New contexts are getting created for each request. ⏳

That is still fine but if there are more than 1k requests – 1k times object will be created and disposed, unless you have made it a Singleton. ☝🏻

Creating and disposing of so many objects may impact the performance. ❌

How DbContextPooling can help❓

https://t.me/pgimg/117

[ Article ] : http://bit.do/dbpol

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core
@ProgrammingTip
Using MariaDB with ASP.NET Core 2.0 🌊

What is MariaDB❓

MariaDB is a community-developed fork of the MySQL relational database management system intended to remain free under the GNU GPL. 🐧

Development is led by some of the original developers of MySQL, who forked it due to concerns over its acquisition by Oracle Corporation. πŸ’Ž

Basically it is a fork of MySQL which is guaranteed to stay open source, and as noted it is supposed to be a drop-in replacement for MySQL. ✨

So let’s put this to the test with a simple ASP.NET Core application. πŸ”₯

https://t.me/pgimg/118

[ Article ] : bit.do/mariad

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Core #MariaDB #MySql
@ProgrammingTip
18 Interesting Things from jQuery ✨

jQuery is one of the most popular JavaScript libraries in use today. πŸ’Ž

It is the library that is beloved by most of the web developers for scripting. πŸ‘Ύ

In this article I'm going to share you some of the interesting things from that library. πŸ”₯

https://t.me/pgimg/119

[ Article ] : bit.do/jqint

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #jQuery
@ProgrammingTip
Blazor πŸ”₯

An experimental .NET web framework using C#/Razor and HTML that runs in the browser via WebAssembly that is supported by Microsoft. πŸ’Ž

Blazor is a .NET web framework that runs in any browser. 🌐

Blazor uses only the latest web standards. No plugins or transpilation needed. βœ…

It runs in the browser on a real .NET runtime (Mono) implemented in WebAssembly that executes normal .NET assemblies. ⚑️

It works in older browsers too by falling back to an asm.js based .NET runtime. πŸ‘΄πŸΏ

Blazor will have all the features of a modern web framework, including ✨ :
β€’ Components
β€’ Routing
β€’ Layouts
β€’ Forms and validation
β€’ Dependency injection
β€’ JavaScript interop
β€’ Live reloading
β€’ Server-side rendering
β€’ Full .NET debugging


https://t.me/pgimg/120

[ Github ] : bit.do/blazor
[ Learn ] : learn-blazor.com
[ Flight Finder ] : bit.do/ffinder
[ Sample CRUD ] : bit.do/bzcrud

γ€°γ€°γ€°γ€°γ€°γ€°
#Blazor #AspMvc #Core
@ProgammingTip
Avoid Lazy Loading Entities in ASP.NET Applications πŸ™…πŸ»β€β™‚οΈ

Lazy Loading is an Entity Framework feature that lets you worry less about the specific amount of data you need to fetch with a given query. 😌

Instead, you write simple queries, and Entity Framework will load the minimal amount of data (which is a good thing), and then will only fetch additional data on an as-needed basis. βœ…

That is, rather than eager loading all of the related data a given entity might have, lazy loading is a technique that has EF perform the minimal amount of work needed up front, and then only performs additional work if it turns out to be necessary. ⚠️

This sounds like a great feature, but you should turn it off in your ASP.NET web apps. 🚫

This article explains why you should do this. 🧐


https://t.me/pgimg/121

[ Article ] : bit.do/lazyy

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #LazyLoading
@ProgrammingTip
Ngrok πŸ”₯

Ngrok allows you to expose a web server running on your local machine to the internet. 🌐

Just tell ngrok what port your web server is listening on :πŸ‘‚πŸ»

ngrok http [port] -host-header="localhost:[port]"


Result βœ… :

Tunnel Status : online
Version : 2.0/2.0
Web Interface : 127.0.0.1:4040
Forwarding : http://92832de0.ngrok.io
Forwarding : https://92832de0.ngrok.io


You can now access your website from ✨ :
http://92832de0.ngrok.io

When you start ngrok, it will display a UI in your terminal with the public URL of your tunnel and other status and metrics information about connections made over your tunnel πŸ› .


Inspecting Your Traffic πŸ“Š

Ngrok provides a real-time web UI where you can introspect all of the HTTP traffic running over your tunnels. πŸ‘€

After you've started ngrok, just open http://localhost:4040 in a web browser to inspect request details. πŸŒ€


https://t.me/pgimg/122

[ Docs ] : ngrok.com/docs

γ€°γ€°γ€°γ€°γ€°γ€°
#Ngrok #Testing
@ProgrammingTip
A shorter and URL friendly GUID ✨

This a small helper class in C#. πŸ‘Ύ

The class encodes a GUID into a 22 character long string and decodes the string back to the original GUID again. βœ…

It takes a standard GUID like this πŸ”¬ :
c9a646d3-9c61-4cb7-bfcd-ee2522c8f633


And converts it into this smaller string πŸ’Ž :
00amyWGct0y_ze4lIsj2Mw


It basically just converts a GUID into a base64 string and shortens it a bit. ⚑️


https://t.me/pgimg/123

[ Article ] : bit.do/guids

γ€°γ€°γ€°γ€°γ€°γ€°
#CSharp #GUID
@ProgrammingTip
Programming Tips πŸ’‘
Photo
ASP.NET Core.2 & Angular 5.pdf
7.3 MB
ASP.NET Core 2 & Angular 5 - Full Stack Web Development with .NET Core & Angular πŸ“•

Author : Valerio De Sanctis πŸ–Š

Publisher : Packt πŸ’Ž

γ€°γ€°γ€°γ€°γ€°γ€°
#Book #AspMvc #Core #Angular
@ProgrammingTip