Cypress - Get Attribute value and store in Variable Last Updated : 23 Jul, 2025 Comments Improve Suggest changes Like Article Like Report In Cypress, you can retrieve an attribute value of an element using the .invoke() method. This is helpful when you need to store an attribute value for further use in your test. For instance, you might want to grab the value of a href, id, or src attribute from an element and then perform assertions or reuse the value in other steps.In this example, we will demonstrate how to get the value of an element’s attribute, store it in a variable, and then use that variable in subsequent test steps.HTML Code HTML <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Attribute Value Example</title> </head> <body> <h1>Get Attribute Example</h1> <a id="myLink" href="https://example.com/" target="_blank">Visit Example.com</a> </body> </html> In this HTML code, we have a simple anchor (<a>) tag with the href attribute pointing to an external website and the id attribute for easy access in Cypress.Cypress Test Code JavaScript describe('Get and Store Attribute Value', () => { it('should retrieve the href attribute and store it in a variable', () => { // Visit the page cy.visit('http://localhost:3000'); // Declare a variable to store the attribute value let hrefValue; // Get the href attribute from the anchor tag and store it cy.get('#myLink') .invoke('attr', 'href') .then((href) => { hrefValue = href; // Log the value to verify cy.log('The href value is: ' + hrefValue); // Use the href value in an assertion or other steps expect(hrefValue).to.equal('https://example.com/'); }); // Additional actions using the hrefValue cy.log('Using hrefValue for another step'); }); }); ExplanationVisit the Page:We use cy.visit('http://localhost:3000') to navigate to the page containing the anchor tag.Retrieve the Attribute Value:Cypress retrieves the href attribute of the anchor tag using cy.get('#myLink').invoke('attr', 'href').We use .then() to store the attribute value in the hrefValue variable.Logging the Value:We log the attribute value using cy.log() to ensure it’s captured correctly.Assertion:The expect(hrefValue).to.equal('https://example.com/') statement checks that the value of the href attribute is as expected.Further Actions:After retrieving the value, you can use it in further test steps. For example, you could use it in navigation, additional assertions, or to interact with other elements.Output:After running the test, Cypress will log the following output:The href value is: https://example.com/The test will also pass if the href value matches 'https://example.com/'.OutputConclusionUsing .invoke('attr', ...) in Cypress allows you to retrieve and store the value of any attribute from an element. This can be particularly useful when working with dynamic elements, links, or other attributes that need to be accessed throughout the test. By storing the attribute value in a variable, you can use it in assertions or further steps in your test. This provides flexibility and control over how you interact with and validate elements during test execution. Comment More infoAdvertise with us C codersaksyevt Follow Improve Article Tags : Software Testing Testing Tools Cypress Similar Reads Software Testing Tutorial Software testing is an important part of the software development lifecycle that involves verifying and validating whether a software application works as expected. It ensures reliable, correct, secure, and high-performing software across web, mobile applications, cloud, and CI/CD pipelines in DevOp 10 min read What is Software Testing? Software testing is an important process in the Software Development Lifecycle(SDLC). It involves verifying and validating that a Software Application is free of bugs, meets the technical requirements set by its Design and Development, and satisfies user requirements efficiently and effectively.Here 11 min read Principles of Software testing - Software Testing Software testing is an important aspect of software development, ensuring that applications function correctly and meet user expectations. From test planning to execution, analysis and understanding these principles help testers in creating a more structured and focused approach to software testing, 3 min read Software Development Life Cycle (SDLC) Software Development Life Cycle (SDLC) is a structured process that is used to design, develop, and test high-quality software. SDLC, or software development life cycle, is a methodology that defines the entire procedure of software development step-by-step. The goal of the SDLC life cycle model is 8 min read Software Testing Life Cycle (STLC) The Software Testing Life Cycle (STLC) is a process that verifies whether the Software Quality meets the expectations or not. STLC is an important process that provides a simple approach to testing through the step-by-step process, which we are discussing here. Software Testing Life Cycle (STLC) is 7 min read Types of Software Testing Software testing is a important aspect of software development life-cycle that ensures a product works correctly, meets user expectations, and is free of bugs. There are different types of software testing, each designed to validate specific aspects of an application, such as functionality, performa 15+ min read Levels of Software Testing Software Testing is an important part of the Software Development Life Cycle which is help to verify the product is working as expected or not. In SDLC, we used different levels of testing to find bugs and errors. Here we are learning those Levels of Testing in detail.Table of ContentWhat Are the Le 4 min read Test Maturity Model - Software Testing The Test Maturity Model (TMM) in software testing is a framework for assessing the software testing process to improve it. It is based on the Capability Maturity Model(CMM). It was first produced by the Illinois Institute of Technology to assess the maturity of the test processes and to provide targ 8 min read SDLC MODELSWaterfall Model - Software EngineeringThe Waterfall Model is a Traditional Software Development Methodology. It was first introduced by Winston W. Royce in 1970. It is a linear and sequential approach to software development that consists of several phases. This classical waterfall model is simple and idealistic. It is important because 13 min read What is Spiral Model in Software Engineering?The Spiral Model is one of the most important SDLC model. The Spiral Model is a combination of the waterfall model and the iterative model. It provides support for Risk Handling. The Spiral Model was first proposed by Barry Boehm. This article focuses on discussing the Spiral Model in detail.Table o 9 min read What is a Hybrid Work Model?Hybrid means a thing made by a combination of two different elements and the resulting hybrid element acquires characteristics of both underline elements. The following topics of the hybrid model will be discussed here:What is the Hybrid Model?Why the Hybrid Model?When To Use a Hybrid ModelProcess o 13 min read Prototyping Model - Software EngineeringPrototyping Model is a way of developing software where an early version, or prototype, of the product is created and shared with users for feedback. The Prototyping Model concept is described below: Table of ContentWhat is Prototyping Model?Phases of Prototyping ModelTypes of Prototyping ModelsAdva 7 min read SDLC V-Model - Software EngineeringThe SDLC V-Model is a type of Software Development Life Cycle (SDLC). It is a method that includes testing and validation alongside each development phase. It creates a structure like the letter 'V,' which includes various phases that we will discuss in detail.Phases of SDLC V-ModelThe V-Model, whic 9 min read TYPES OF TESTINGManual Testing - Software TestingManual testing is an important part of software development. Unlike automated testing, it involves a person actively using the software to find bugs and issues. This hands-on approach helps ensure the software works as intended and meets user needs. Table of ContentWhat is Manual Testing Types of Ma 14 min read Automation Testing - Software TestingAutomated Testing means using special software for tasks that people usually do when checking and testing a software product. Nowadays, many software projects use automation testing from start to end, especially in agile and DevOps methods. This means the engineering team runs tests automatically wi 15+ min read Like